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内 容 简 介 


本 书 由 浅 入 深 地 讲解 了 PHP 的 各 项 知识 。 主 要 包括 PHP 的 常量 与 变量 、 运 算 符 与 表达 式 、 流 程控 制 、 函 数 、 数 据 
处 理 、 文 件 应 用 、 主 机 信息 、 图 像 处 理 、Session 与 Cookie、 正 则 表达 式 的 使 用 、 面 向 对 象 编程 、MySQL 数据 库 知 识 。 
另外 ， 本 书 还 精 选 了 多 个 常用 模块 ， 分 别 是 计数 器 程序 、 网 上 投票 系统 、 留 言 板 程序 、 简 单 的 BBS 系统 、 博 客 程序 、 
网 上 商城 系统 。 实 例 结合 实际 功能 需要 ， 符 合 系统 设计 要 求 ， 并 且 都 是 当前 流行 的 应 用 系统 。 

本 书 适合 希望 从 事 或 正在 从 事 PHP+MySQL 系统 开发 的 人 员 阅 读 、 借 鉴 和 参考 ， 同 时 也 适合 各 类 学 校 作为 教材 使 
用 。 另 外 ， 它 还 是 学 生 毕 业 设 计 的 好 参考 书 。 


本 书 封面 贴 有 清华 大 学 出 版 社 防伪 标签 ， 无 标签 者 不 得 销售 。 
版 权 所 有 ， 侵 权 必 究 。 侵 权 举 报 电话 : 010-62782989 13501256678 13801310933 
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编辑 寄语 


“不 积 趾 步 ， 无 以 至 千里 。” 
一 一 中 国 思想 家 茄子 


“网 站 开发 非常 之 旅 ”这 套 书 自 2006 年 开始 已 经 陆续 推出 了 近 10 个 品种 ， 这 些 品种 大 都 受到 了 
读者 的 热烈 欢迎 。 自 出 版 后 这 套 书 中 的 大 多 数 图 书 已 经 多 次 印刷 ， 销 售 居 同 类 图 书 前 列 。 对 于 计算 机 
图 书 ， 这 是 一 个 让 人 振奋 的 结果 。 

根据 一 年 以 来 读者 的 反馈 可 以 看 出 ， 他 们 比较 一 致 地 认为 这 套 书 定位 明确 ， 内 容 有 特色 ， 编 写 质 
量 较 好 ， 看 后 能 学 到 真正 有 用 的 东西 ， 而 且 售后 服务 和 技术 支持 做 得 非常 好 。 我 们 从 中 不 难看 出 这 套 
书 受 欢迎 的 原因 。 

为 了 让 读者 更 加 全 面 地 了 解 这 套 书 ， 下 面具 体 介绍 这 套 书 的 定位 、 内 容 、 特 色 、 读 者 对 象 等 。 


丛书 定位 


根据 读者 的 实际 需求 ， 本 丛书 并 不 追求 面面俱到 ， 而 是 定位 于 实用 ， 并 注重 对 基本 知识 点 的 掌握 
和 对 基本 技能 的 提升 。 突 出 体现 在 以 下 几 点 : 
回 ”每 本 书 大 体 都 对 应 着 相应 的 工作 岗位 ， 着 重 让 读者 掌握 一 项 技能 ， 使 他 们 在 学 完 一 本 书 以 后 ， 
可 以 将 所 学 应 用 到 实际 工作 中 去 。 
回 ”讲解 概念 ， 但 并 不 拘泥 于 概念 ， 而 是 侧重 于 对 概念 的 灵活 运用 ， 从 而 让 读者 在 实践 中 加 深 对 
概念 的 理解 和 对 基本 知识 的 掌握 。 
加 不 安排 纯 演示 性 实例 ， 那 种 实例 通常 没有 任何 应 用 价值 ， 读 者 很 难 通 过 它 而 达到 较 好 的 应 用 
水 平 。 本 从 书 中 的 实例 大 多 选 自 于 实际 开发 ， 是 对 作者 多 年 开发 经 验 的 总 结 。 读 者 通过 对 这 
些 实例 的 学 习 ， 可 以 真正 体验 实际 的 开发 过 程 ， 从 而 将 所 学 应 用 于 实践 。 


丛书 书目 
第 一 批 : 
《ASP 网 络 编程 从 入 门 到 精通 》 《ASP.NET 网 络 数据 库 开 发 实例 精 解 》 
《ASP+SQL Server 典型 网 站 建设 案例 》 《服务 器 配置 全 攻略 》 
第 二 批 : 
《ASP.NET 2.0 网 络 编程 从 入 门 到 精通 》 《Dreamweaver 网 页 制作 与 色彩 搭配 全 攻略 》 
《ASP.NET 2.0+SQL Server 网 络 应 用 系统 开 《JavaScript 网 页 特效 实例 大 全 》 


发 案例 精 解 》 《HTML 网 页 设计 参考 手册 》 


Se PHP 网 络 编程 从 入 门 到 精通 


第 三 批 ; 
《JSP 网 络 编程 从 入 门 到 精通 》 《Dreamweaver 网 页 设计 与 制作 完全 手册 》 
《PHP 网 络 编程 从 入 门 到 精通 》 《Dreamweaver+ASP 动态 网 站 开发 从 入 门 
《PHP+MySQL 经 典 案例 剖析 》 到 精通 》 
《Ajax 经 典 案例 开发 大 全 》 《CSS 标准 网 页 布局 开发 指南 》 

丛书 特色 


回 ”本 丛书 按照 网 站 开发 的 流程 组 织 内容 ， 从 最 初 的 服务 器 配置 ， 到 后 台 编码 的 实现 ， 到 前 台 网 
页 设计 等 内 容 均 有 涉及 ， 真 正 实现 了 网 站 开发 一 条 龙 。 学 完 本 丛书 ， 读 者 可 以 全 面 掌 握 网 站 
开发 的 各 项 技术 。 

加 ”作者 均 为 有 丰富 的 网 络 编程 经 验 的 一 线 开 发 人 员 ， 可 以 确保 技术 的 先进 性 、 实 用 性 和 深入 性 。 

回 内容 讲解 到 位 ， 避 免 室 洞 ， 每 个 知识 点 都 配 有 实例 ， 读 者 可 以 上 机 操作 ， 体 会 其 中 的 奥妙 。 

回 ”贯穿 丰富 的 应 用 实例 ， 并 专门 设计 了 综合 案例 ， 让 读者 真正 做 到 学 以 致 用 ， 并 领会 项 目 开发 
的 整体 思路 。 

B ” 配 视频 讲解 光盘 ， 将 一 些 简 单 的 、 操 作 性 强 的 内 容 放 到 光盘 中 ， 以 加 速 读 者 的 学 习 ， 并 节省 
篇 幅 ， 降 低 定价 ， 让 读者 真正 得 到 实惠 。 

B ”提供 必要 的 售后 服务 。 丛 书 的 每 本 书 都 有 相应 的 技术 论坛 与 作者 E-mail ( 见 前 言 ) ， 读 者 若 
有 疑问 ， 可 以 按 此 寻求 帮助 。 


读者 对 象 
回 ”网 站 建设 及 网 络 开发 人 员 回 “网 页 制作 爱好 者 
加 ”网 页 设计 及 制作 人 员 回 ” 大 中 专 院 校 的 学 生 
回 ”网 站 维护 人 员 加 ”毕业 设计 的 学 生 


“不 积 哇 步 ， 无 以 至 千里 ”。 我 想 这 句 话 可 能 最 能 概括 这 套 书 成 功 的 真正 原因 。 这 套 书 要 想 走 得 
远 ， 就 得 一 步 一 个 脚印 地 做 好 各 个 环节 的 工作 。 从 对 读者 需求 的 调研 ， 到 确立 写作 思路 ， 到 选择 作者 ， 
到 后 期 编辑 及 制作 ， 乃 至 技术 服务 等 ， 都 得 一 一 落实 。 只 有 这 样 ， 才 能 给 这 套 书 的 继续 发 展 葛 定 基础 ， 
才能 让 这 套 书 继续 成 为 广大 读者 的 良师益友 。 

在 “网 站 开发 非常 之 旅 ”第 三 批 图 书 即将 出 版 之 时 ， 作 为 这 套 书 的 编辑 ， 自 是 有 感 而 发 ， 希 望 这 
套 书 能 一 如 既往 地 以 高 质量 、 高 品质 和 读者 见面 ， 同 时 也 希望 这 套 书 能 继续 受到 读者 的 关注 和 青睐 。 


本 书 编辑 (oyzx_sp@263.net) 
2007 年 6 月 于 清华 园 


区 


HI 


mp 


在 这 个 数字 化 时 代 ， 全 世界 有 千 千 万 万 个 网 站 昼夜 不 停 地 提供 服务 。PHP+MySQL 这 一 对 Web 应 
用 开发 的 利器 ， 在 从 电子 商务 到 网 络 办 公 ， 从 邮件 服务 〈 例 如 eYou) 到 大 型 综合 网 站 (例如 Yahoo! ) 
的 广泛 应 用 ， 都 显示 了 其 强大 的 功能 。 对 于 从 事 Web 应 用 开发 的 从 业 人 员 或 想 进入 该 领域 的 未 来 精英 
而 言 ， 掌 握 PHP+MySQL 技术 是 必需 的 技能 。 

为 帮助 Web 应 用 从 业者 快速 掌握 PHP+MySQL 开发 技术 ,笔者 精心 编著 了 本 书 。 本 书 遵 循 由 浅 入 
深 ， 循序 渐进 的 学 习 规律 ， 充 分 考虑 语言 学 习 的 特点 ， 紧 密 结合 开发 实例 ， 体 系 完整 地 介绍 了 PHP 网 
络 程序 开发 技术 。 


本 书 特 色 


1. 笔者 多 年 从 事 PHP 编程 ， 深 知 一 个 初学 者 在 学 习 PHP 这 门 技术 中 会 遇 到 哪些 实际 问题 。 笔 者 
通过 本 书 总 结 出 了 初学 者 在 学 习 PHP 时 经 常 出 现 的 问题 ， 并 对 这 些 问 题 一 一 做 了 解答 。 这 样 的 做 法 会 
使 初学 者 少 走 不 少 弯路 。 

2. 本 书 是 一 本 基础 性 书籍 ， 由 浅 入 深 地 对 PHP 作 了 全 面 讲解 ， 涉 及 PHP 常用 的 函数 及 功能 ， 对 
每 个 函数 及 功能 都 给 出 了 实例 ， 非 常 便于 操作 。 

3. 在 本 书 的 后 半 部 分 讲解 了 PHP 中 常用 的 模块 实例 ， 内 容 包 括 计数 器 程序 、 网 上 投票 系统 、 留 
言 板 程序 、 简 单 的 BBS 系统 、 博 客 程序 及 网 上 商城 系统 儿 个 部 分 。 实 例 结合 实际 功能 需要 ， 符 合 系统 
设计 要 求 ， 并 且 均 是 网 上 流行 的 应 用 系统 。 

4. 本 书 内 所 列举 的 代码 ， 不 论 是 只 有 几 行 的 小 程序 或 是 有 上 千 行 的 大 型 程序 都 经 过 了 严格 的 调 
试 运行 ， 都 是 可 以 正常 运行 的 。 

5. 配 多 媒体 视频 演示 光盘 ， 让 读者 快速 入 门 。 


本 书 内 容 


本 书 共 分 为 4 篇 。 其 中 第 1 篇 PHP 基础 ， 包 括 第 1~2 章 ; 第 2 篇 PHP 核心 技术 ,包括 第 3~15 章 ; 
第 3 篇 PHP 常用 模块 ， 包 括 第 16~19 章 ; 第 4 篇 PHP 综合 应 用 实例 ， 包 括 第 20~21 章 。 

第 1 章 介绍 PHP 基本 知识 。 通 过 本 章 ， 读 者 可 以 了 解 静 态 网 页 和 动态 网 页 的 区 别 、 什 么 是 PHP 及 
PHP 的 发 展 和 特点 。 本 章 最 后 通过 一 个 实例 ， 让 读者 对 PHP 有 一 个 基本 的 认识 。 

第 2 章 介绍 如 何 构建 PHP 开发 环境 。 内容 包括 服务 器 Apache、PHP 解释 器 、 数 据 库 服务 器 MySQL 
和 管理 器 及 代码 编辑 器 EditPlus 的 安装 和 配置 。 

第 3 章 介绍 PHP 常量 和 变量 。 通 过 本 章 ， 读 者 可 以 学 习 PHP 中 常量 和 变量 的 使 用 。 本 章 还 着 重 介 
绍 数组 的 使 用 。 

第 4 章 介绍 PHP 运算 符 和 表达 式 。 通 过 本 章 , 读者 可 以 学 习 PHP 中 各 种 运算 符 的 使 用 和 表达 式 的 
创建 。 
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第 5 章 介 绍 PHP 的 流程 控制 语句 。 这 些 语句 包括 判断 语句 让 ..else、while、do.…while 及 for 循环 
语句 。 

第 6 章 介绍 PHP 函数 的 使 用 。 内 容 包括 函数 的 构成 、 定 义 、 调 用 和 递归 。 

第 7 章 介绍 PHP 数据 的 处 理 。 内 容 包括 数据 类 型 的 判断 、 数 学 函数 的 应 用 、 字 符 串 的 处 理 和 数组 
的 处 理 等 。 

第 8 章 介绍 PHP 文件 和 目录 操作 。 内 容 包括 文件 的 打开 、 读 取 、 删 除 和 目录 的 创建 、 删 除 。 本 章 
最 后 还 介绍 文件 操作 应 用 实例 一 一 在 线 相册 系统 的 实现 方法 。 

第 9 章 介 绍 主机 信息 的 获取 。 内 容 包 括 浏 览 器 、IP、 时 间 信 息 的 获取 和 处 理 。 

第 10 章 介绍 PHP 的 图 像 处 理 。 内 容 包括 图 像 函数 的 使 用 、 图 片 水 印 的 生成 、 直 方 图 的 绘制 、 缩 
略图 的 生成 等 。 

第 11 章 介 绍 Session 和 Cookie 的 处 理 。 通 过 本 章 学 习 ， 读 者 可 以 掌握 Session 和 Cookie 的 定义 和 
使 用 ， 并 且 掌 握 网 页 风格 变换 的 实现 方法 。 

第 12 章 介绍 正则 表达 式 的 使 用 。 内 容 包 括 POSIX 和 Perl 正则 表达 式 的 构建 和 应 用 。 本 章 最 后 还 
将 介绍 E-mail 校 验 和 UBB 中 正则 表达 式 的 应 用 。 

第 13 章 介绍 PHP 面向 对 象 编程 的 基础 知识 。 内 容 包括 类 的 封装 、 继 承 、 重 载 和 类 相关 函数 的 
使 用 。 

第 14 章 介 绍 MySQL 数据 库 的 使 用 。 内 容 包括 MySQL 的 使 用 、SQL 语句 的 使 用 。 本 章 最 后 通过 
一 个 学 生 档案 系统 ， 介 绍 MySQL 使 用 流程 。 

第 15 章 介 绍 PHP 中 人 机 交互 的 实现 。 内 容 包括 表单 数据 的 处 理 和 URL 值 传递 的 处 理 。 

第 16 章 介绍 计数 器 的 实现 。 通 过 本 章 ， 读 者 可 以 掌握 简单 计数 器 、 图 形 计数 器 、 多 用 户 计 数 器 的 


实现 方法 。 
第 17 章 介绍 网 上 投票 系统 的 实现 。 该 系统 实现 投票 的 管理 、 投 票 统计 等 功能 ， 并 对 防止 重复 投票 
做 专门 的 讲解 。 


第 18 章 介绍 留言 板 系统 的 实现 。 该 系统 实现 留言 数据 的 文件 保存 、 前 台 留 言 和 后 台 管理 功能 。 

第 19 章 介绍 博客 系统 的 实现 。 该 系统 实现 用 户 登 录 和 注册 、 日 志 添加 和 修改 、 留 言 管理 等 功能 。 

第 20 章 介绍 BBS 系统 的 实现 。 该 系统 实现 BBS 的 常用 功能 ， 如 用 户 注册 和 登录 、 主 题 的 显示 和 
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要 想 学 习 PHP， 先 要 了 解 到 底 什么 是 PHP， 如 何 使 用 PHP。 本 章 将 回答 这 些 问题 。 
通过 对 本 章 的 学 习 ， 将 使 读者 对 PHP 及 其 发 展 过 程 有 一 个 大 致 的 了 解 。 同 时 将 学 会 如 
何 把 PHP 代码 加 入 到 普通 Web R P, 如何 为 PHP 代码 加 入 注释 以 及 PHP 的 文件 引用 
的 将 性 。 

本 章 介 绍 如 何 编 写 一 个 PHP 文件 。 在 学 习 本 章 时 有 几 个 问题 需要 注意 : 第 1， 对 
<%%> 的 代码 使 用 方法 要 谨慎 使 用 ; 第 2, 注意 不 要 使 用 多 行 注释 ; 第 3, 采用 include 
和 require 方法 引用 文件 时 ， 被 引用 的 文件 必须 存在 。 
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1.1 关于 静态 网 页 与 动态 网 页 


目前 网 上 的 网 页 有 静态 网 页 与 动态 网 页 两 种 形式 。 在 讲 这 两 种 网 页 之 前 ， 先 了 解 一 下 网 络 构成 中 
的 客户 机 (Browser) 与 服务 器 (Server) 。 服 务 器 是 安装 有 服务 软件 可 以 向 客户 机 提供 诸如 网 页 浏览 、 
数据 库 查询 等 服务 的 设备 。 而 客户 机 则 与 之 相反 ， 它 通过 客户 端 软 件 如 网 页 浏览 器 从 服务 器 上 获得 如 
网 页 浏览 、 软 件 下 载 等 服务 。 简 单 地 讲 ， 服 务 器 就 是 服务 提供 者 ， 而 客户 机 则 是 服务 获得 者 。 


1.1.1 传统 的 静态 网 页 HTML 


在 WWW 发 展 的 早期 阶段 ， 由 于 受 技术 条 件 的 制约 ， 服 务 器 提供 给 用 户 的 网 页 基本 都 是 静态 的 
HTML 页 。 这 种 网 页 通常 只 包含 HTML 标识 ， 没 有 脚本 代码 。 这 类 网 页 在 视觉 上 也 可 能 出 现 “ 动 ”的 
效果 ， 如 通过 GIF 动画 、Flash、JavaScript 特 效 等 内 容 来 丰富 网 页 。 但 是 用 户 每 次 浏览 ， 该 网 页 的 内 容 
都 是 一 成 不 变 的 。 


静态 网 页 服务 的 实现 流程 如 下 : 客户 端 通过 浏览 器 向 服务 器 发 出 请 求 ， 服 务 器 根据 请 求 从 服务 器 
端的 网 页 中 选 出 合适 的 页 面 发 送 给 客户 端 浏览 器 。 这 
个 过 程 中 所 发 送 的 页 面 都 是 事先 编辑 好 的 , 它 并 不 能 发 送 请 求 CD 
自动 生成 。 静 态 网 页 的 实现 模式 如 图 1.1 所 示 。 z q 服 
静态 网 页 有 以 下 儿 个 特点 : 机 传 回 页 面 各 
口 静态 网 页 不 能 自动 更 新 。 由 于 不 能 自动 更 
新 , 所 以 如 果 要 对 静态 页 面 进行 更 新 , 就 要 图 1.1 静态 网 页 的 实现 模式 


重新 编写 HTML 页 然后 再 上 传 。 因 此 静态 
网 页 制作 和 维护 的 工作 量 相当 大 。 

O 静态 网 页 的 内 容 不 随 浏览 用 户 、 浏 览 时 间 等 条 件 的 变化 而 变化 。 无 论 何人 、 何 时 、 何 地 浏览 
网 页 ， 它 的 内 容 都 是 一 成 不 变 的 不 包括 使 用 JavaScript 实现 一 些 简单 特效 ) 。 

O 静态 网 页 一 经 发 布 , 无 论 浏览 者 浏览 与 否 , 它 都 是 实 实在 在 存在 的 一 个 文件 , 都 对 应 一 个 URL 
(统一 资源 定位 符 ， 指 的 是 Intemet 文件 在 网 上 的 地 址 ) 。 

口 用 静态 网 页 实现 人 机 交互 有 相当 大 的 局 限 性 。 由 于 不 能 动态 生成 页 面 ， 所 以 用 静态 网 页 来 实 
现 人 机 交互 是 很 困难 的 ， 它 在 功能 上 有 很 大 限制 。 
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随 着 网 络 技术 的 不 断 发 展 ， 各 种 动态 网 页 技术 也 纷纷 显示 出 它们 的 不 凡 魅 力 。 先 是 早期 出 现 的 
CGI， 又 有 现在 流行 的 ASP、PHP、JSP、ASP.NET、ColdFushion 等 。 虽 然 这 些 动态 语言 分 属于 不 同 公 
司 开发 (其 中 ASP 与 ASP.NET 同属 微软 公司 ) ， 也 有 着 不 同 的 运行 环境 和 使 用 方法 ， 但 它们 的 目标 
是 一 样 的 ， 就 是 实现 网 页 浏览 者 与 网 页 之 间 的 互动 。 

与 静态 网 页 的 实现 方法 不 同 ， 动 态 网 页 服务 的 实现 过 程 如 下 : 客户 端 向 服务 器 提出 申请 ， 服 务 器 
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根据 用 户 请 求 ， 把 动态 网 页 内 部 的 代码 先 在 服务 器 上 进行 相应 的 处 理 ， 再 把 生成 的 结果 发 送 给 客户 端 。 


其 模式 如 图 1.2 所 示 。 
通过 以 上 分 析 ， 与 静态 网 页 相 比 ， 动 态 网 页 有 以 下 | 发 送 请 求 C D 
客 
户 
机 


儿 个 特点 : ya 服 

口 “动态 网 页 在 服务 器 端 运行 。 客户 机 上 看 到 的 只 你 | 各 
是 它 的 返回 结果 ， 不 能 看 到 它 的 源 文件 。 而 更 < 
态 网 页 则 只 能 通过 服务 器 把 网 页 文件 原封 不 
动 地 传 给 客户 机 ， 本 身 不 进行 任何 处 理 。 图 12 动态 网 页 的 实现 模式 

口 。 不 同 的 用 户 、 不 同时 间 、 不 同 地 点 浏览 同一 个 动态 网 页 ， 根 据 代码 处 理 结果 不 同 ， 会 返回 不 
同 的 内 容 。 

口 。 动态 网 页 只 有 经 用 户 浏览 时 才 会 返回 一 个 完整 的 网 页 ， 而 其 本 身 并 不 是 一 个 独立 存在 于 服务 
器 的 网 页 文件 。 


口 “ 与 静态 网 页 相 比 ， 动 态 网 页 更 容易 实现 人 机 交互 。 与 数据 库 相 联系 ， 能 实现 更 为 强大 的 功能 。 
口 “动态 网 页 构建 的 网 站 维护 起 来 比 静态 网 页 要 容易 ， 只 需要 更 新 调用 的 数据 〈 如 数据 库 内 容 ) 
即 可 。 
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1.1 节 为 读者 介绍 了 静态 网 页 与 动态 网 页 。 而 PH 就 是 动态 网 页 技术 中 的 一 种 。 那 么 到 底 什 么 是 
PHP， 它 的 发 展 历史 是 怎么 样 的 呢 ? 与 其 他 动态 网 页 技术 相 比 ，PHP 都 有 些 什 么 特点 呢 ? 本 节 将 为 读 
者 来 解答 这 些 问题 。 


1.2.1 什么 是 PHP 


早期 有 人 将 PHP 解释 为 Personal Home Page， 即 个 人 主页 。 也 有 人 将 PHP 称 作 “PHP: Hypertext 
Preprocessor”( 这 是 一 个 递归 的 简称 ， 简 称 之 中 又 是 简称 ) 。 那 么 到 底 什么 是 PHP 呢 ? 通俗 地 说 ，PHP 
是 一 种 服务 器 端 、 跨 平台 、HTML 嵌入 式 的 脚本 语言 。 服 务 器 端 执 行 的 特性 表明 它 是 动态 网 页 的 一 种 。 
跨 平 台 ， 则 是 指 PHP 不 仅 可 以 运行 在 Linux 系统 上 ， 同 时 也 可 以 运行 在 UNIX 或 者 Windows 系统 上 。 
另外 ， 它 还 可 以 很 简单 地 嵌入 到 普通 的 HTML 页 中 ， 用 户 所 要 做 的 只 是 在 普通 HTML 页 中 加 入 PHP 
代码 即 可 。 


1.2.2 PHP 的 发 展 历史 


PHP 最 初 在 1994 年 由 Rasmus Lerdorf 进 行 开 发 .用户 用 到 的 第 1 个 版 本 是 在 1995 年 发 布 的 Personal 
Home Page Tools (PHP Tools) 。 在 这 个 早期 的 PHP 版 本 中 只 提供 了 对 访客 留言 本 、 访 客 计 数 器 等 简 
单 功能 的 支持 。1995 年 中 期 又 发 布 了 PHP 的 第 2 个 版 本 ， 定 名 为 PHP/FI (Form Interpreter) 。 到 1996 
年 时 PHP/FI2.0 已 经 应 用 于 分 布 在 世界 各 地 的 15000 个 网 站 上 了 。 
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1997 年 开始 了 第 3 版 的 开发 计划 ， 开 发 小 组 加 入 了 Zeev Suraski 及 Andi Gutmans， 而 第 3 版 就 定 
名 为 PHP 3。 这 个 版 本 的 PHP 具有 以 下 特点 : 与 Apache 服务 器 紧密 结合 ; 加 入 了 更 多 的 新 功能 ; 支持 
几乎 所 有 主流 与 非 主 流 的 数据 库 ; 高 速 的 执行 效率 等 。 由 于 PHP 3 的 这 些 特性 ， 使 得 1999 年 中 使 用 
PHP 的 网 站 超过 了 150000! 

2000 年 5 月 ，PHP 4 正式 发 布 。 它 使 用 了 Zend (Zeev+Andi) 引擎 ， 提 供 更 高 的 性 能 ， 还 包含 了 其 
他 一 些 关键 功能 ， 如 支持 更 多 的 Web 服务 器 、HTTP Sessions 支持 、 输 出 缓存 (output buffering) 、 更 
安全 的 处 理 用 户 输入 的 方法 以 及 一 些 新 的 语言 结构 等 。PHP 4 是 更 有 效 的 、 更 可 靠 的 动态 Web 页 开发 
工具 。 在 大 多 数 情况 下 运行 比 PHP 3 快 ， 其 脚本 描述 更 强大 ， 并 且 更 复杂 ， 最 显著 的 特征 是 速率 比 的 
增加 。 

2004 年 7 月 ，PHP 5 问世 。 无 论 对 于 PHP 语言 本 身 ， 还 是 对 于 PHP 的 用 户 来 讲 ，PHP 5 的 发 布 都 
算得 上 是 一 个 里 程 碑 式 的 版 本 。PHP 5 的 诞生 ， 使 PHP 编程 进入 了 一 个 新 时 代 。Zend I 引擎 的 采用 ， 
完备 对 象 模型 、 改 进 的 语法 设计 , 终于 使 得 PHP 成 为 一 个 设计 完备 、 真正 具有 面向 对 象 能 力 的 脚本 语言 。 


1.2.3 PHP 与 其 他 CGI 程序 相 比 较 


同样 作为 服务 端 编程 语言 ，PHP 与 其 他 CGI 程序 如 ASP、JSP 等 相 比 有 其 自身 的 特点 。 主 要 表现 
在 以 下 儿 个 方面 : 

O Web 服务 器 支持 方面 ,PHP HEIHE Apache, IS 等 多 种 服务 器 支持 , 而 ASP 则 只 能 被 Windows 
系统 下 的 IIS, PWS 所 支持 。 

O 运行 平台 的 支持 。PHP 能 够 很 好 地 运行 于 Linux, UNIX, Windows, FreeBSD 等 多 种 操作 系 
统 上 。 而 ASP 只 能 运行 于 Windows 系统 上 。 虽 然 JSP 也 能 在 多 种 系统 下 得 到 支持 , 但 必须 以 
有 Java 虚拟 机 为 前 提 。 

口 脚本 语言 不 同 。PHP 本 身 就 是 一 种 编程 语言 ， 它 是 吸收 了 C Java 等 语言 的 综合 优势 而 创建 
开发 的 一 种 新 语言 。ASP 严格 来 说 并 不 是 一 种 单纯 的 编程 语言 ， 而 是 一 种 网 络 编程 支持 环境 ， 
它 支持 VBScript, JavaScript, Perl 等 多 种 语言 ， 但 一 般 默认 使 用 VB 作为 主要 编程 语言 。 而 
JSP 使 用 Java 编程 语言 或 JavaScript 作为 脚本 语言 。 

O 数据库 支 持 不 同 。PHP 通常 与 MySQL 数据 库 结合 使 用 ， 同 时 它 还 支持 包括 Oracle, Sybase, 
ODBC 等 多 种 数据 库 。ASP 则 通常 与 同属 微软 公司 的 Access, MSSQL 等 数据 库 配合 使 用 。 
T JSP 则 使 用 JDBC 来 实现 与 数据 库 的 连接 。 

O 面向 对 象 的 支持 不 同 。ASP 基本 上 是 由 组 件 所 构成 的 ， 而 组 件 是 对 象 的 使 用 模式 ， 因 此 ASP 
中 对 象 的 使 用 频率 非常 高 ， 可 以 说 处 处 都 是 对 象 。JSP 是 建立 在 可 重用 的 、 跨 平台 的 组 件 之 上 
的 ， 所 以 它 的 面向 对 象 特性 也 非常 明显 。 在 PHP 5 出 现 以 前 ，PHP 系列 基本 上 是 属于 面向 过 
程 的 ，PHP 5 的 出 现 改 变 了 这 种 状况 ， 真 正 实现 了 面向 对 象 。 


1.3 第 1 个 程序 一 一 HELLO WORLD! 


学 习 一 门 新 的 编程 语言 ， 都 需要 从 最 基本 的 程序 开始 。 根 据 约定 俗 成 的 、 最 基本 的 程序 就 是 
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“HELLO WORLD!”。 这 一 节 ， 就 来 介绍 怎么 在 PHP 编程 环境 中 实现 这 一 个 最 基本 的 程序 。 (读者 
在 学 习 本 节 之 前 先 保证 已 经 构建 了 PHP 运行 环境 ， 如 果 没有 请 参看 本 书 第 2 章 的 相关 内 容 ) 


1.3.1 在 页 面 中 加 入 PHP 代码 


PHP 是 一 种 可 媒 入 的 语言 。 也 就 是 说 ， 它 可 以 很 方便 地 加 入 到 一 般 常 见 的 HTML 页 中 。 用 户 请 求 
PHP 文件 时 ， 相 关 的 PHP 代码 先 在 服务 器 端 解释 执行 ， 生 成 新 的 HTML 信息 ， 再 连同 原 有 的 HTML 
代码 一 起 发 送 给 用 户 。 下 面 通过 一 个 实例 来 讲解 怎样 向 普通 HTML 页 中 加 入 PHP 代码 。 


<html> 

<head> 

<title>HELLO WORLD!</title> 

</head> 

<body> 

< 上 -以 上 为 普通 HTML 代码 ， 以 下 为 PHP 代码 -> 
<? 

echo "HELLO WORLD!"; NA echo 打印 字符 串 
?> 

<!-- 以 上 为 PHP 代码 --> 

</body> 

</html> 


把 以 上 代码 保存 为 一 个 PHP 文件 “1-1.php”。.php 为 PHP 文件 ， 本 书后 面 将 多 次 出 现 。 在 PHP 
运行 环境 下 (如 果 读 者 还 没有 PHP 运行 环境 ,请 参看 本 书 第 2 章 ) 执行 以 上 代码 ， 结 果 如 图 1.3 所 示 。 
单 从 执行 结果 来 看 ， 上 面 这 段 代 码 确实 比 单纯 的 HTML 代码 没有 多 执行 任何 东西 。 而 事实 上 并 非 
如 此 。 页 面 中 显示 的 “HELLO WORLD!” 是 经 过 服务 器 的 解释 才 转 到 客户 端的 。 其 执行 机 理 如 图 1.4 


所 示 。 
发 送 请 求 E 
(Annan tonm — Microsoft Tatecnet keri oca E ja 释 服 
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HELLO WORLD! 
到 
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图 1.3 HELLO WORLDI! 执 行 结果 图 1.4 PHP 执行 机 理 


经 过 上 例 可 以 发 现 ， 把 PHP 代码 加 入 普通 HTML 页 中 ， 只 需要 在 HTML 页 中 加 入 PHP 代码 的 标 
记 “<?”、“9?>” 符 号 ， 这 些 符 号 的 中 间 即 为 PHP 代码 。 这 些 代码 会 先 在 服务 器 上 被 解释 ， 然 后 再 把 
结果 连同 普通 HTML 一 起 返回 给 客户 浏览 器 。 上 例 中 的 PHP 代码 即 为 通过 PHP 中 的 ECHO 语句 ， 打 
印 出 一 段 字 符 串 “HELLO WORLD!”。 

当然 ， 使 用 “<?2> ”标记 只 是 把 PHP 代码 加 入 到 普通 HTML 页 中 的 一 种 方法 。 除 此 之 外 还 有 以 下 
几 种 方法 : 

O 使 用 <?php ?> 标记 。 

O 使 用 <script language="PHP"></script> 标 记 。 
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O ”使 用 ASP 语言 的 <% %> 标 记 , 不 过 这 取决 于 用 户 服务 器 的 相关 配置 , 有 可 能 不 会 被 解释 执行 ， 
即 原封 不 动 返回 客户 端 。 


1.3.2 在 PHP 页 中 加 入 注释 


pA 
To 


要 有 


每 种 语言 都 有 自己 的 注释 方法 ，PHP 也 不 例外 。 注 释 的 内 容 并 不 被 执行 ， 它 可 以 是 任何 内 容 。 通 
注释 的 目的 是 为 了 向 别人 说 明 自己 的 程序 ， 所 以 应 该 是 对 程序 、 语 句 的 解释 。 一 个 好 的 程序 不 仅 


友好 的 、 完 善 的 代码 ， 同 时 也 要 有 清晰 的 、 易 于 理解 的 注释 。 在 程序 中 加 入 注释 是 对 自己 工作 的 
也 是 对 别人 的 一 种 尊重 。 

下 面 还 采用 1.3.1 节 的 例子 来 说 明 怎样 在 PHP 代码 中 加 入 注释 。 

<html> 

<head> 

<title>HELLO WORLD!</title> 

</head> 

<body> 

< 上 -以 上 为 普通 HTML 代码 ， 以 下 为 PHP 代码 -> 

<? 

echo "HELLO WORLD!"; INEM ECHO 语句 打印 字 串 

yA 

PHP 对 多 行内 容 的 注释 

这 里 有 多 行内 容 

gd 

?> 

<!-- 以 上 为 PHP 代码 --> 

</body> 

</html> 


通过 上 例 知道 ， 为 PHP 代码 加 入 注释 ， 通 常 有 两 种 方法 : 一 种 是 单行 注释 使 用 “/” 标 记 ; 另 一 


种 是 多 行 注释 使 用 “/* ”标记 
注意 : 在 使 用 多 行 注释 标识 的 时 候 ， 一 定 不 要 使 用 多 重 注释 。 像 下 面 注释 的 使 用 ， 必 然 会 引起 错误 。 


又 有 注释 出 现 了 ， 这 是 错误 的 
强 

| 

?> 


EPH 中 ， 多 行 注释 并 不 支持 嵌 套 。 


1.3.3 文件 的 引用 


PHP 支持 文件 的 引用 。 这 意味 着 用 户 可 以 把 一 些 全 局 变量 、 专 用 函数 放 到 专门 的 文件 中 ， 需 要 的 
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时 候 ， 来 引用 这 个 文件 。 文 件 被 引用 ， 就 可 以 使 用 其 中 的 变量 和 函数 了 ， 就 像 在 一 个 PHP 文件 中 一 样 
方便 。PHP 有 两 种 引用 文件 的 方法 : require 和 include。 下 面 仍 通过 一 个 实例 来 实际 说 明 这 两 种 方法 。 
<? 


$string="HELLO WORLD!" /定义 变量 
?> 


这 段 代码 只 是 定义 了 一 个 字符 串 变量 。 把 上 面 的 代码 保存 为 “1-2.php”。 


<html> 
<head> 
<title> 使 用 include 引用 文件 </title> 


include("1-2.php"); // 使 用 include 引用 文件 
echo $string; 

?> 

</body> 

</html> 


把 上 面 的 代码 保存 为 “1-2.php”， 与 string.php 放 在 同一 个 目录 下 。 在 PHP 环境 里 运行 test.php， 
执行 结果 和 图 1.3 是 一 样 的 。 

同 理 还 可 以 用 

require "文件 名 "; 
来 引用 文件 ， 使 用 效果 与 

include(" 文 件 名 "); 
是 一 样 的 。 


1.4 本 章 小 结 


KEMAT PHP 的 基本 知识 。 第 1 节 介绍 了 静态 网 页 与 动态 网 页 ; 第 2 节 主要 讲解 了 什么 是 PHP， 
PHP 的 发 展 历史 ; 第 3 节 讲 解 了 怎样 在 页 面 中 加 入 PHP 代码 及 注释 和 PHP 对 文件 的 引用 。 通过 对 本 章 
的 学 习 读者 对 什么 是 PH 及 怎么 使 用 PHP 应 该 有 一 个 大 致 的 了 解 了 。 在 实际 使 用 时 要 注意 以 下 问题 ; 

O 加 入 PHP 代码 的 方法 <%%> 应 谨慎 使 用 ， 因 为 如 果 服务 器 配置 不 支持 这 种 方法 ， 则 相应 的 代 

码 不 会 被 执行 ， 而 是 原封 不 动 地 显示 给 用 户 。 
O ” 嵌 套 使 用 多 行 注释 标记 会 导致 错误 。 
口 不 管用 何 种 方法 引用 文件 , 被 引用 的 文件 必须 是 存在 的 文件 。 如 果 文 件 不 存在 ， 也 会 导致 错误 。 
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通过 第 1 章 的 学 习 可 知 ，PHP 是 一 种 服务 器 端 编 程 语言 。 所 以 要 想 运行 PHP 代码 ， 
必须 有 相应 的 服务 器 环境 及 解释 器 。PHP 能 够 在 多 种 服务 器 环境 上 运行 ， 但 是 PHP 的 
“黄金 搭配 "还 是 PHP+Apache+Linux。 但 是 作为 通用 操作 系统 ,Linux 远 没 有 Windows 
那么 流行 。 所 以 本 书 的 环境 就 条 用 PHP+Apache+Windows 这 样 的 形式 。 本 章 将 介绍 
怎样 在 Windows 操作 系统 下 安装 、 配 置 PHP 的 运行 环境 。 
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调试 PHP 程序 需要 安装 以 下 组 件 。 

Apache: 运行 Web 页 面 的 服务 器 程序 。 

PHP: PHP 程序 的 解释 器 。PHP 页 面 会 先 通过 该 解释 器 解释 再 发 送 给 用 户 。 

MySQL: MySQL 数据 库 程序 。 调 试 数据 库 程序 的 必 备 服务 。 

phpMyAdmin: 用 PHP 编写 的 管理 MySQL 数据 库 的 程序 。 使 用 该 程序 可 以 有 效 管理 MySQL 
数据 库 。 

EditPlus: PHP 文件 的 编辑 器 。 可 以 编辑 任何 二 进 制 文件 。 


(mE mii ma m 
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2.1 Windows 平台 下 Apache 的 安装 


Apache 是 运行 PHP 程序 最 好 的 服务 器 系统 。 通 常情 况 下 ，Apache 都 是 运行 于 Linux 操作 系统 上 
的 ， 但 Apache 也 有 Windows 版 。 本 书 采 用 Apache 的 Windows 版 来 搭建 服务 器 环境 。 
Apache 可 以 在 其 官方 网 站 http://www.apache.org 上 下 载 。 本 书 使 用 apache 2.2.3 for win32 版 本 (其 
实 不 同 版 本 的 区 别 对 初学 者 来 说 不 是 太 大 ) 。 下 载 到 的 是 一 个 Msi 文件 。 双 击 即 可 安装 。 最 简单 的 方 
法 是 采用 一 路 回 车 法 。 其 中 有 几 项 要 向 读者 作 介绍 。Apache 的 安装 共 分 以 下 几 步 : 
(1) 首先 弹出 的 是 欢迎 使 用 界面 。 单 击 Next 按钮 ， 弹 出 License Agreement 对 话 框 ， 如 图 2.1 
所 示 。 
(2) 选中 accept the terms in the license agreement 选项 ， 单 击 Next 按钮 ， 进 入 下 一 个 对 话 框 。 
G) 该 对 话 框 对 Apache 简单 介绍 。 单 击 Next 按钮 ， 弹 出 Server Information 对 话 框 ， 如 图 2.2 
所 示 。 
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(4) 在 Network Domain 文本 框 中 输入 域名 。 如 果 只 是 在 本 机 上 调试 程序 ， 而 并 不 是 想 架 设 一 
网 络 服务 器 ， 则 只 需 填 入 本 机 IP (127.0.0.1) 即 可 。 在 Server Name 文本 框 中 输入 服务 器 的 名 字 ， 这 里 
输入 “localhost”。 在 Administrator's Email Address 文本 框 中 输入 网 络 管理 员 的 电子 信箱 。for All Users, 
on Port 80, as a Service-Recommended. 选项 为 允许 所 有 用 户 使 用 Apache 服务 ; only for the Current 
User ,on Port 8080, when started Manually. 选项 只 允许 当前 用 户 使 用 Apache 服务 。 这 里 选中 第 1 项 。 单 
击 Next 按钮 ， 弹 出 Setup Type 对 话 框 ， 如 图 2.3 所 示 。 
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CS) Typical 选项 为 标准 安装 ，Custom 选项 为 自 定义 安装 ， 这 里 选中 Custom 选项 。 单 击 Next 按 
钮 ， 弹 出 Custom Setup 对 话 框 ， 如 图 2.4 所 示 。 
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图 2.3 Setup Type 对 话 框 图 2.4 Custom Setup 对 话 框 


(6) 单 击 Change 按钮 ， 选 择 安装 目录 ， 默 认为 C:\Program Files。 为 了 调试 方便 ， 这 里 选择 
C:\Apache。 单 击 Next 按钮 ， 弹 出 Ready to Install the Program 对 话 框 ， 如 图 2.5 所 示 。 

(7) 单 击 Install 按钮 开始 进行 安装 。 安 装 结束 后 ， 弹 出 Installation Wizard Completed 对 话 框 ， 如 
图 2.6 所 示 。 
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图 2.5 Ready to Install the Program 对 话 框 图 2.6 Installation Wizard Completed 对 话 框 


(8) 该 对 话 框 提示 用 户 Apache 已 经 安装 成 功 ， 单 击 Finish 按钮 完成 安装 。 
安装 成 功 后 ， 打 开 IE 输入 “http:/127.0.0.1”， 结 果 如 图 2.7 所 示 。 至 此 ，Apache 的 安装 过 程 全 部 
结束 。 
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2.7 ”测试 成 功 Apache 正常 工作 
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2.2 PHP 解释 器 的 安装 


这 一 节 来 完成 PHP 的 安装 及 相关 配置 。 因 为 Apache 只 支持 传统 的 HTML, 要 想 体 验 PHP 的 魅力 ， 
必须 要 安装 PHP 解释 器 。 与 Apache 相 比 ，PHP 的 安装 就 要 简单 一 些 ， 因 为 PHP 解释 器 通常 是 以 ZIP 
包 的 形式 提供 ， 只 需 在 解压 缩 后 进行 相关 配置 即 可 。 

PHP 解释 器 可 以 从 其 官方 网 站 : http://www.php.net/ 上 获取 。 这 里 选择 php-5.1.6 的 Win32 版 。 该 版 
本 提供 有 两 种 形式 ， 一 种 是 安装 包 的 形式 ， 另 一 种 是 ZIP 包 的 形式 。 这 里 选用 ZP 包 。 把 下 载 的 ZIP 
压缩 包 解 压 到 C 盘 PHP 目录 下 。 解 压缩 后 ， 需 要 做 以 下 几 步 工作 。 

A) 打开 Ci\php 中 的 文件 install.txt， 找 到 如 下 内 容 : 


ScriptAlias /php/ "c:/php/" 
AddType application/x-httpd-php .php 


#For PHP 4 
Action application/x-httpd-php "/php/php.exe" 


#For PHP 5 
Action application/x-httpd-php "/php/php-cgi.exe" 
把 这 段 内 容 复制 到 Apache 的 配置 文件 httpd.conf (该 文件 位 于 C:\Apache\conf F) 。 
(2) 右 击 Windows 状态 栏 的 图 标 短 ， 选 择 open apache monitor 命令 ， 打 开 Apache 管理 器 ， 如 
图 2.8 所 示 。 
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图 2.8 Aapache Service Monitor 


G) 单 击 Restart 按钮 ， 重 启 Apache 服务 。 
(4) 把 文件 php.ini-dist 改名 为 php.ini。 
(5) 将 php 目录 里 的 php5ts.dll，libmysql.dll 复制 到 系统 目录 Ci\windows 中 。 
(6) 到 Ci\php\ext 下 将 php_gd2.dll、php_mysql.dll 这 两 个 文件 复制 到 系统 目录 Ci:\windows\ 
system32 里 。 
(7) 重启 Apache 服务 器 。 
下 面 测 试 Apache 对 PHP 的 支持 。 在 C:\Apache\htdocs 目录 下 ， 新 建文 件 2-1.php， 加 入 如 下 代码 : 
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<? 
phpinfo(); 
?> 


在 浏览 器 中 输入 “http://localhost/2-1.php”， 结 果 如 图 2.9 所 示 。 出 现 该 界面 说 明 PHP 安装 成 功 。 


图 2.9 testphp 执行 结果 


2.3 MySQL 的 安装 


PHP 通常 与 MySQL 数据 库 配合 使 用 ， 所 以 学 习 PHP 就 得 必须 学 习 MySQL 数据 库 技 术 。 因 此 ， 
读者 需要 安装 相应 的 MySQL 数据 库 。 这 一 节 来 介绍 如 何 获取 与 安装 MySQL 数据 库 。 


2.3.1 MySQL 的 安装 


读者 首先 应 到 MySQL 的 官方 网 站 http://www.mysql.com 下 载 MySQL 的 Windows 版 本 。 通常 下 载 
的 是 一 个 Msi 的 安装 包 ， 直 接 双 击 运行 该 安装 程序 即 可 。 整 个 安装 过 程 共 分 以 下 几 步 : 
(1) 首先 弹出 欢迎 界面 ， 单 击 Next 按钮 ， 进 入 Setup Type 对 话 框 ， 如 图 2.10 所 示 。 

(2) MySQL 提供 3 种 安装 模式 : Typical 选项 为 标准 安装 ;Complete 选项 为 完全 安装 ; Custom 
选项 为 自 定义 安装 。 这 里 选择 Custom 选项 , 单 击 Next 按钮 ,弹出 Custom Setup 对 话 框 , 如 图 2.11 所 示 。 
(3) 单 击 Change 按钮 ， 更 改 安装 目录 为 CN\MySQL。 单 击 Next 按钮 ， 弹 出 安装 确认 界面 。 

(4) 确认 安装 后 ， 单 击 Install 按钮 ， 开 始 安装 。 

(5) 在 安装 过 程 中 会 弹出 MySQL.com Sign-Up 对 话 框 ， 如 图 2.12 所 示 。 
(6) 选中 Skip Sign-Up 选项 ， 单 击 Next 按 钮 即 可 。 

(7) 安装 完成 ， 弹 出 Wizard Completed 对 话 框 ， 如 图 2.13 所 示 。 
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图 2.12 MySQL.com Sign-Up 对 话 框 图 2.13 MySQL 安装 第 5 步 


选中 Configure the MySql servernow 选项 ， 单 击 Finish 按钮 ， 完 成 安装 过 程 ， 开 始 对 MySQL 服务 
进行 配置 。 


2.3.2 MySQL 的 配置 


在 安装 完成 后 ， 开 始 对 MySQL 服务 进行 配置 。 整 个 配置 过 程 有 以 下 几 步 : 

(1) 首先 弹出 欢迎 界面 ， 单 击 Next 按钮 ， 进 入 MySQL Server Instance Configuration 对 话 框 ， 如 
图 2.14 所 示 。 

(2) Detailed Configuration 选项 为 细节 配置 ，Standard Configuration 为 标准 配置 。 这 里 选中 Standard 
Configuration 选项 ， 然 后 单 击 Next 按钮 ， 进 入 MySQL Server Instance Configuration 对 话 框 ， 如 图 2.15 
所 示 。 

(3) Install As Windows Service 选项 为 安装 为 Windows 的 系统 服务 ; Include Bin Directory in 
Windows PATH 选项 用 命令 行 启动 MySQL。 这 里 只 选择 第 2 项 ， 然 后 单 击 Next 按钮 ， 进 入 配置 确认 
对 话 框 。 

(4) 如 果 确 认 无 误 ， 单 击 Execute 按钮 ， 执 行 配置 。 

(5) 单 击 Finish 按钮 ， 即 可 完成 配置 。 
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Configure the my5Qt Server 5.0 server instence, 


Please set the Windows options. 


7 Install As Windows Service 
Thisis the recommended way to run the MYSQL server 
an Windows. 


FF Launch the MySQL Server automaticaly 


deee] 
E 
UA AA 
AI 


<B coa | 
图 2.14 MySQL 配置 过 程 第 2 步 图 2.15 MySQL 配置 第 3 步 


2.3.3 修改 php.ini 以 支持 MySQL 


打开 Ci\php 目录 下 的 php.ini 文件 。 找 到 
;extension=php_mysql.dll 


这 一 行内 容 。 去 掉 前 面 的 分 号 , 保存 php.ini 文件 。 重 新 启动 服务 即 可 让 PHP 支持 MySQL. E C:\Apache\ 
htdocs 目录 下 新 建 一 个 PHP 文件 2-2.php， 输 入 以 下 内 容 : 


<?php 

$link=mysql_connect('localhost','root',"); /该 函数 是 进行 MyYQL 主机 连接 的 函数 ， 其 中 的 root 和 空 
密码 是 MySQL 的 用 户 和 密码 ， 请 根据 自己 的 情况 改 好 

if(ISlink) echo "失败 "; /如果 连 接 失败 ， 输 出 失败 信息 

else echo "成 功 "; // 如 果 连 接 成 功 ， 输 出 成 功 信息 


mysql_close(); 
?> 


先 开启 MySQL 服务 。 开 启 方法 : 执行 C:\mysql\bin\ 目 录 下 的 mysqld-nt.exe 文件 ，MySQL 服务 即 
在 后 台 运 行 。 


[Bh /i 0 0 /22 pip > wi masa S E] 

然后 在 PHP 运行 环境 下 执行 2-2.php， 执行 结果 如 四 | 

2 成 功 = 

图 2.16 所 示 。 mai EN zi 
出 现 如 图 2.16 所 示 结 果 ， 说 明 MySQL 已 经 正常 


irii 图 2.16 WR MySQL 是 否 成 功 安装 
运行 。 


2.4 安装 phpMyAdmin 


安装 完 MySQL 数据 库 后 ， 要 建 库 、 表 ， 修 改 各 种 数据 库 、 表 等 工作 。 如 果 这 些 工作 都 在 命令 行 
模式 下 进行 ， 一 方面 非常 麻烦 ， 另 一 方面 也 需要 有 专业 的 SQL 数据 知识 才 行 。 可 喜 的 是 ， 现 在 已 经 有 
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了 可 视 化 的 MySQL 数据 管理 工具 phpMyAdmin。 该 工具 采用 PHP 编写 ， 可 以 完美 运行 在 各 种 版 本 的 
PHP 及 MySQL 下 。 这 一 节 讲 解 如 何 安装 phpMyAdmin. 
用 户 可 以 通过 网 站 http:/www.phpmyadmin.net/home_page/index.php 下 载 到 phpMyAdmin 的 最 新 
版 。 安 装 过 程 分 以 下 几 步 : 
(1) 把 下 载 到 的 压缩 包 解 压 到 C:\apache\htdocs\ 目 录 下 。 把 目录 改名 为 phpmyadmin。 
(2) 复制 libraries/config.default.php 到 phpmyadmin 目录 下 ， 并 改名 为 config.inc.php。 
G) 找到 config.inc.php 中 的 如 下 代码 : 


$cfg['Servers'][$ilruser] = 'root', /MySQL user 
$cfg['Servers'][$il[password] =" /I MySQL password (only needed) 


把 其 中 的 内 容 替 换 为 MySQL 的 用 户 名 和 相应 的 密码 即 可 。 
读者 还 需要 测试 phpMyAdmin 是 否 正 常 工作 。 在 浏览 器 中 输入 http://127.0.0.1/phpmyadmin/index.php。 
其 执行 结果 如 图 2.17 所 示 。 


localhost 
加 服务 器 版 本 : 5.0.27- 
- community-nt 
> Protocolversion. 10 
Ey DRAE: localhost via 
数据 库 TCPAP 
| 数据 库 ) z] > 用户: root@ocalhost 
[FE Bwsa. FHR: UTF-8 
z Unicode (utf8) 
haia Emsa ER: 
uf unicode dl 了 
@ 
司 多 创建 一 个 新 的 数据 库 zi 
Wa KA KA AI Ee A 


图 2.17 phpMyAdmin 执行 结果 
出 现 如 图 2-17 所 示 结 果 说 明 phpMyAdmin 正常 运行 ，phpMyAdmin 安装 完成 。 


2.5 EditPlus 的 安装 


PHP 文件 属于 二 进 制 文件 ， 所 以 可 以 采用 所 有 通用 的 文本 编辑 器 来 进行 编辑 ， 如 常见 的 记事 本 、 
写字 板 、Word 等 。 不 过 这 些 程序 都 不 是 专 为 编写 程序 代码 而 设计 ， 在 编写 代码 时 功能 有 限 。 这 里 为 读 
者 推荐 一 款 功 能 强大 的 文本 编辑 软件 一 一 EditPlus， 用 它 来 编辑 PHP 代码 。 

用 户 可 以 在 其 官方 网 站 http:/www.editplus.com/ 上 下 载 到 EditPlus。 由 于 是 英文 软件 ， 所 以 建议 安 
装 相应 的 汉化 补丁 。 网 上 也 有 很 多 该 软件 的 汉化 补丁 。 该 软件 及 补丁 与 普通 软件 一 样 ， 安 装 过 程 相当 
简单 ， 不 再 袭 述 。 安 装 后 ， 和 运行 该 软件 ， 打 开工 具 菜单 下 的 “参数 ”对 话 框 ， 选 择 【 文 件 】|【 设 置 与 
语法 】 命 令 ， 弹 出 如 图 2.18 所 示 对 话 框 。 

在 右上 方 的 “文件 类 型 ”列表 框 中 选择 PHP 选项 ， 然 后 选中 右 下 方 的 “关联 当前 文件 类 型 ” 复 选 
框 。 然 后 单 击 的 “应 用 ”按钮 。 这 样 所 有 的 PHP 文件 默认 被 EditPlus 打开 ， 完 成 配置 。PHP 的 开发 环 
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境 全 部 安装 完毕 。 

xl 
a30 HRED 

Piy Ear a Emo 
sa” s x L 
au so: BE oooO 

Ea smew e o ë 

BIA 设置 与 滞 法 ) | 语法 竺 色拉 ) | 


APIA 

WA aaao ai _ aero 

zmr | 
aasma 
SHERU ucha A] RA 

厂 添加 到 “ 文 牢 关 型 "” NEN iza 

mua EA 


Ya X JAW ZEDD 


图 2.18 EditPlus 的 配置 
26 本 章 小 结 
开发 环境 是 进行 PHP 编程 的 基础 ， 有 了 相应 的 环境 才能 进行 开发 。 本 章 内 容 中 Apache 的 安装 相 


对 简单 ， 而 PHP 安装 过 程 中 由 于 要 修改 配置 文件 ， 所 以 相对 麻烦 。 而 且 由 于 版 本 兼容 性 问题 ， 有 时 需 
要 安装 相应 补丁 才能 正常 运行 ， 这 一 点 需要 引起 读者 注意 。 
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PHP 中 的 图 像 处 理 
PHP 中 的 Session 与 Cookie 
PHP 中 正则 表达 式 的 使 用 
PHP 面 向 对 象 编程 

使 用 MySQL 数 据 库 


用 PHP 实 现 人 机 交互 
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PHP FAHRE 
PHP PARE 
PHP 让 预定 义 变量 的 使 用 
PHP 中 数组 型 变量 的 使 用 


š 于 于 至 


常量 与 变量 是 构成 程序 的 基石 ,所 以 每 种 编程 语言 中 都 会 有 本 类 语言 所 对 应 的 常量 
与 变量 。 作 为 一 门 网 络 编程 语言 ，PHP 也 不 例外 。 本 章 将 详细 介绍 有 关 PHP 中 的 常量 
与 变量 的 知识 。 通 过 本 章 的 学 习 ， 读 者 将 会 学 习 到 什么 是 常量 、 什 么 是 变量 ; 在 PHP 
中 如 何 使 用 预定 义 常量 与 交 量 ; 如 何 自 定义 常量 与 变量 等 。 
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3.1 PHP 中 常量 的 定义 与 使 用 


常量 是 在 程序 运行 中 值 始终 不 会 发 生 改 变 的 一 类 量 。 在 进行 PHP 编程 时 经 常 要 用 到 这 类 数据 ， 如 
打开 文件 的 文件 名 、 文 件 的 路 径 等 这 些 系统 常量 以 及 用 户 自 定义 一 些 的 常量 。 本 小 节 将 介绍 PHP 中 的 


常量 。 
3.11 定义 使 用 常量 


常量 在 使 用 前 必须 定义 ,否则 程序 在 执行 时 就 会 出 错 。 在 PHP 中 使 用 define() 函 数 来 定义 常量 。 其 
语法 格式 如 下 : 

define("Name","value"); 

其 中 的 Name 为 定义 常量 的 常量 名 ，value 为 常量 代表 的 值 。 

下 面 就 通过 一 个 实例 来 介绍 一 下 PHP 中 的 常量 的 定义 与 使 用 。 

<html> 


<head> 
<title>PHP 中 常量 的 定义 与 使 用 </title> 


define("STANDARD_H","HELLO WORLD!"); /定义 常量 STANDARD_H, 并 赋值 为 HELLO WORLD 
echo STANDARD H; /使 用 echo 打印 常量 
?> 
</body> 
</html> 
保存 以 上 代码 为 PHP 文件 “3-1.php”。 然 后 在 PHP 运行 环境 下 运行 以 上 代码 ， 运 行 效果 如 图 3.1 
所 示 。 习 Pi 中 第 量 的 定义 与 使 用 ~ Kiraia 
常量 的 命名 不 是 随意 的 ， 必 须 符合 一 定 的 规则 。PHP 中 EEEE EA 
常量 的 命名 有 以 下 规则 : 合法 的 常量 名 以 字母 或 下 划 线 开始 ， 人 li 
后 面 跟着 任何 字母 ， 数 字 或 下 划 线 。 iat ll ss 
常量 与 变量 的 不 同 之 处 体现 在 以 下 儿 个 方面 : 图 3.1 定义 使 用 常量 输出 结果 
常量 前 面 没有 美元 符号 $， 而 变量 则 必须 以 美元 符号 开头 。 
常量 只 能 用 define0 函 数 定义 ， 而 不 能 通过 赋值 语句 定义 。 
常量 可 以 不 用 理会 变量 范围 的 规则 ， 可 以 在 任何 地 方 定义 和 访问 。 
常量 一 旦 定义 就 不 能 被 重新 定义 或 者 取消 定义 ， 并 且 其 值 不 能 发 生 改 变 ， 而 变量 的 值 可 以 随 
时 发 生 改变 。 这 也 是 常量 与 变量 最 根本 的 不 同 。 
常量 的 值 只 能 是 标量 ， 即 整 型 、 浮 点 型 、 字 符 串 3 种 类 型 。 


OOODD 


(m) 


3.1.2 PHP 中 的 预定 义 常 量 
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除了 使 用 自 定义 常量 之 外 ，PHP 还 为 用 户 预 定义 了 系统 常量 ， 常 见 的 系统 常量 及 其 含义 如 表 3.1 
所 示 。 
表 3.1 PHP 中 的 预定 义 常量 

常 量 名 说 AA 

FILE PHP 文件 的 文件 名 

LINE PHP 文件 的 行 数 
PHP VERSION PHP 程序 的 版 本 ， 如 4.0.2 
PHP OS 执行 PHP 解释 器 的 操作 系统 名 称 ， 如 Windows 
TRUE 真 
FALSE 假 
E ERROR 最 近 的 错误 处 
E WARNING 最 近 的 警告 处 
E PARSE 剖析 语法 有 潜在 问题 处 
E NOTICE 发 生 不 寻常 但 不 一 定 是 错误 处 


用 - 


以 上 这 些 以 “E_” 开 头 形 式 的 常数 ， 可 以 参考 Error_ Reporting0 函 数 。 下 面 通过 一 个 实例 来 实际 应 


-下 PHP 中 的 预定 义 常量 。 


<hmtl> 
<head> 
<title>PHP 中 预定 义 常量 的 使 用 </title> 


echo "所 使 用 的 文件 名 是 :"; 
echo FILE ; 

echo "<br>"; 

echo "文件 的 行 数 为 :"; 
echo LINE ; 

echo "<br>"; 

echo "PHP 的 版 本 是 :"; 
echo PHP VERSION; 

echo "<br>"; 

echo "所 使 用 的 操作 系统 为 :"; 
echo PHP_OS; 

?> 

</body> 

</html> 


// 输 出 当前 文件 名 
/输出 HTML 换行 符 
/| 输出 文件 行 数 
/输出 PHP 版 本 


/输出 操作 系统 类 型 


保存 以 上 代码 为 “3-2.php”。 在 PHP 运行 环境 下 执行 以 上 代码 。 执 行 结 果 如 图 3.2 所 示 (当然 ， 
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实际 输出 会 因 操 作 系统 、PHP 版 本 的 不 同 而 有 所 出 入 ， 但 大 体 上 是 一 样 的 ) 。 


注意 : 不 论 是 使 用 自 定 义 常 量 还 是 系统 预定 义 常量 ， 大 小 写 都 必须 一 致 。 如 使 用 系统 预定 义 常量 时 把 
大 写 改 为 小 写 ， 就 不 能 正确 返回 预定 义 常 量 PHP_ VERSION 所 定义 的 PHP 版 本 号 ， 而 是 返回 


“php_version” 这 个 字符 串 。 


<? 

echo PHP VERSION; /输出 PHP 版 本 
echo "<p>"; /输出 HTML 换行 符 
echo php version; // 输 出 字符 串 

?> 


把 以 上 这 段 代 码 保 存 为 “3-3.php”， 在 PHP 执行 环境 下 运行 ， 其 执行 结果 如 图 3.3 所 示 。 


APPR REMEH ~ Microsoft Tiarna Ea = „igxi 
ZPO MAV STV HAW IAV WHW | 


aioi xi 
XEO MAD 查看 WD HRY IAV 帮助 WD | 那 


PERDEZ: C: Yapache\htdocs\3-2. T 
TEREI Cache \atdocs\8-2. php 


PHP 的 版 本 是 ，5.1.6 

所 使 用 的 操作 系统 为 ，WTNNT 
COO Er kuu 
图 3.2 使 用 PHP 的 预定 义 常量 图 3.3 预定 义 常量 中 的 大 小 写 


从 图 3.3 所 示 可 以 发 现 ， 大 小 写 不 同 ， 所 输出 的 不 同 结果 。 所 以 ， 使 用 系统 预定 义 常量 时 ， 一 定 要 
注意 大 小 写 问 题 。 


5.1.6 


php version 


BE au CES 


3.2 PHP 中 的 变量 


变量 指 在 程序 运行 过 程 中 值 可 以 随时 发 生 改变 的 一 类 值 。PHP 是 一 个 弱 类 型 的 语言 〈 弱 类 型 语言 
指 在 使 用 变量 时 不 用 指定 变量 的 类 型 ， 在 使 用 时 也 没有 类 型 检查 的 一 类 编程 语言 ) ， 所 以 在 使 用 变量 
时 ， 不 用 事先 指定 变量 类 型 ， 在 使 用 时 根据 上 下 文 由 系统 解释 器 来 判断 变量 的 类 型 。 另 外 PHP 也 不 像 
其 他 编程 要 先 定 义 才能 使 用 ， 变 量 不 用 事先 定义 即 可 使 用 。 
3.2.1 PHP 的 变量 类 型 
PHP 的 变量 类 型 有 以 下 几 种 : 整 型 变量 (Integer) 、 浮 点 型 变量 (Double) 、 字 符 型 变量 (String ) ~ 
数组 型 变量 (Array) 和 对 象 型 变量 (Object) 。 
口 ” 整 型 变量 在 32 位 操作 系统 中 它 的 有 效 范围 是 : -2 147 483 648~+2 147 483 647。 要 使 用 16 进 
制 整 数 可 以 在 前 面 加 0x。 
O 浮 点 型 变量 在 32 位 操作 系统 中 的 有 效 范围 为 : 1.7E-308~1.7E+308。 
O 字符 型 变量 不 同 于 其 他 编程 语言 有 字符 与 字符 串 之 分 ， 在 PHP 中 ， 统 一 使 用 字符 型 变量 来 定 
义 字符 或 者 字符 串 。 
口 ”数组 型 变量 是 一 种 比较 特殊 的 变量 类 型 ， 将 在 3.4 节 中 详细 说 明 。 
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口 对象 变量 也 是 一 种 比较 特殊 的 变量 。 在 PHP 5 之 前 , PHP 面向 对 象 编程 的 功能 还 不 是 很 强大 。 
PHP 5 改变 了 这 种 状况 。 类 概念 的 引入 ， 使 PHP 真正 成 为 一 种 面向 对 象 的 编程 语言 。 
要 定义 一 个 变量 方法 很 简单 就 是 在 该 变量 名 前 加 上 美元 符号 $。 下 面 的 例子 就 分 别 定义 了 两 个 整 型 
变量 和 两 个 字符 型 变量 。 


/定义 一 个 整 型 变量 ， 赋 值 为 0 
/定义 一 个 整 型 变量 ， 赋 值 为 1253 
/定义 一 个 字符 型 变量 ， 赋 值 为 a 

$string1-"I'm a teacher!"; // 定 义 一 个 字符 串 变量 ， 赋 值 为 “I'm a teacher!” 
?> 


通过 以 上 例子 能 够 发 现 ， 在 PHP 中 定义 一 个 变量 是 一 件 很 简单 的 事情 。 


3.2.2 ”转换 变量 类 型 


在 实际 使 用 PHP 过 程 中 ， 有 时 需要 对 变量 的 类 型 进行 强制 转换 ， 如 要 把 字符 型 变量 改变 为 数值 型 
变量 ， 把 数值 型 变 为 字符 型 等 。 在 PHP 中 可 通过 Settype() 函 数 来 设置 一 个 变量 的 类 型 。 它 的 使 用 方式 
如 下 所 示 : 

settype(mixed var,string type) 

作用 是 将 变量 Var 的 类 型 设置 成 Type。Type 的 可 能 值 ( 即 能 够 转变 的 类 型 为 ， Boolean (或 为 
bool, M PHP 4.2.0 起 ) ~ Integer (或 为 Int， 从 PHP 4.2.0 起 ) 、Float (只 在 PHP 4.2.0 之 后 可 以 使 用 ， 
对 于 旧版 本 中 使 用 的 Double 现 已 停 用 ) 、String、Array、Object、Null (从 PHP 4.2.0 起 ) 。 

如 果 类 型 转换 成 功 则 返回 True， 失 败 则 返回 False。 

下 面 通过 一 个 例子 来 说 明 settype() 函 数 是 怎么 实现 变量 类 型 设置 的 。 


<html> 

<head> 

<title>settype() 函 数 使 用 例子 </title> 

</head> 

<body> 

<? 

$foo="5bar"; /定义 一 个 字符 串 变 量 
$bar=true; // 定 义 一 个 逻辑 值 变 量 

echo $foo; // 输 出 变量 $foo 

echo "<p>"; /| 输出 HTML 回 车 换行 

echo $bar; // 输 出 变量 $bar 

echo "<p>"; 

settype($foo,"integer"); /重新 设置 $foo 的 类 型 为 整 型 
settype( $bar,"string"); /重新 设置 $bar 的 类 型 为 字符 型 
echo $foo; /重新 输出 $foo 

echo "<p>"; 

echo $bar; /重新 输出 $bar 


?> 
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</body> 
</html> 
保存 以 上 代码 为 “3-4.php”， 在 PHP 执行 环境 中 运行 以 上 代码 ， 其 执行 结果 如 图 3.4 所 示 。 
Frettir OARSMAF -出 cres*El Tatari 
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图 3.4 ”settype0 函 数 使 用 例子 执行 结果 
在 使 用 Settype() 函 数 前 ，$Foo 变量 值 为 字符 串 、$Bar 变量 值 为 逻辑 真 值 。 所 以 打印 出 它们 的 值 就 
H: “5bar”、“1”; 在 使 用 Settype() 函 数 后 ，$Foo 变量 值 改变 为 整 型 数 、$Bar 变量 值 改 变 为 字符 串 。 
所 以 打印 的 结果 就 成 了 “5”、“1”。 


3.2.3 ”变量 的 使 用 范围 


和 其 他 编程 语言 一 样 ，PHP 中 的 变量 也 有 全 局 变量 与 局 部 变量 之 分 。 所 谓 全 局 变量 指 在 程序 运行 
期 间 都 能 使 用 的 变量 ， 而 局 部 变量 只 在 子 函 数 或 过 程 中 有 效 。 在 PHP 程序 执行 时 ， 系 统 会 在 内 存 中 保 
留 一 块 全 局 变量 的 区 域 。 实际 运用 时 ,可 以 通过 $SGLOBALS[" 变 量 名 称 "] 的 数组 调用 方法 将 需要 的 全 局 
变量 调 出 。 不 过 需要 注意 的 是 PHP 的 变量 有 大 小 写 之 分 。 如 果 搞 错 了 大 小 写 是 不 能 调 出 来 的 。 

$GLOBALS 数组 是 PHP 程序 中 比较 特殊 的 变量 , 不 必 声 明 系 统 会 自动 匹配 相关 的 变量 在 里 面 。 在 
函数 中 ， 也 不 必 管 SGLOBALS 数组 是 否 已 经 被 声明 ， 就 可 以 直接 使 用 。 

和 $GLOBALS 变量 类 似 的， 还 有 $php_errormsg 字符 串 变 量 。 若 PHP 的 配置 文件 php.ini 中 的 
track errors 选项 值 为 True 的 话 ， 使 用 全 局 变量 $php_errormsg 可 以 看 到 错误 的 讯息 。 

在 PHP 中 ,全 局 变量 的 有 效 范围 只 限于 主 程序 中 ， 不 会 影响 到 函数 中 同名 的 变量 ， 也 就 是 全 局 变 
量 与 局 部 变量 互 不 干扰 。 若 要 全 局 变量 也 能 在 子 函数 中 使 用 ,就 要 用 到 $GLOBALS 数组 或 是 使 用 globals 
宣告 。 

例如 ， 在 自行 开发 的 函数 中 ， 要 取得 目前 执行 PHP 文件 的 文件 名 ， 就 可 以 用 
$GLOBALS["PHP_SELF"] 取 出 $8PHP_SELF 的 值 。 


3.3 PHP 的 预定 义 变量 


PHP 在 系统 中 内 置 了 大 量 与 系统 、 正 在 运行 的 PHP 文件 、HTTP 等 相关 的 变量 ， 如 表 3.2 所 示 。 
了 解 和 使 用 这 些 内 置 变量 对 提高 编程 效率 有 很 大 帮助 。 本 节 将 介绍 一 些 常用 的 PHP 预定 义 变量 ， 更 多 
的 变量 请 参考 Phpinfo0 函 数 所 列 出 的 内 容 。 


名 称 
$_SERVER[PHP SELF] 
$_SERVER[REQUEST METHOD] 
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表 3.2 PHP 中 的 预定 义 变量 
作 用 
当前 正在 执行 的 文件 名 。 返 回 值 与 document root 相 关 


访问 页 面 时 的 请 求 方法 。 例 如 : “GET”、“HEAD”，“POST”，“PUT” 


$ SERVER[DOCUMENT ROOT] 


当前 运行 脚本 所 在 的 文档 根 目录 。 在 APACHE 配 置 文件 中 定义 


$ SERVER(HTTP REFERER] 


链接 到 当前 页 面 的 前 一 页 面 的 URL 地 址 。 不 是 所 有 的 用 户 代理 〈 浏 览 器 ) 都 会 
设置 这 个 变量 ， 而 且 有 的 还 可 以 手工 修改 HTTP_REFERER。 因 此 ， 这 个 变量 不 
总 是 正确 真实 的 


$ SERVER[REMOTE ADDR] 


正在 浏览 当前 页 面 用户 的 耳 地 址 


$ COOKIE 


通过 HTTP cookies 传 递 的 变量 组 成 的 数组 。 是 自动 全 局 变量 


$ GET 通过 HTTP GET 方 法 传递 的 变量 组 成 的 数组 。 是 自动 全 局 变量 

$_POST 通过 HTTP POST 方法 传递 的 变量 组 成 的 数组 。 是 自动 全 局 变量 

$ FILES 通过 HTTP POST 方法 传递 的 已 上 传 文件 项 目 组 成 的 数组 。 是 自动 全 局 变量 
$ REQUEST 此 关联 数组 包含 $ GET，$_POST 和 $_COOKIE 中 的 全 部 内 容 

$ SESSION 包含 当前 脚本 中 已 经 注册 的 session 变 量 的 数组 

$GLOBALS 由 所 有 已 定义 全 局 变量 组 成 的 数组 。 变 量 名 就 是 该 数组 的 索引 


数组 型 变量 是 一 组 具有 相同 类 型 和 名 称 的 变量 的 集合 。 
以 是 一 维 也 可 以 是 多 维 的 ， 数 组 内 元 素 的 类 型 也 可 以 是 数字 、 


3.4.1 


数组 变量 的 初始 化 


3.4 PHP 中 的 数组 型 变量 


它 是 一 种 很 独特 的 变量 ，PHP 中 的 数组 可 
字符 甚至 是 数组 变量 。 


在 PHP 中 初始 化 数组 一 般 有 两 种 方法 ， 一 种 是 同时 给 数组 中 所 有 元 素 赋值 ， 另 一 种 是 单独 给 数组 
每 个 元 素 赋值 。 下 面 通过 实例 来 具体 了 解 这 两 种 方法 。 
3-5.php: 同时 给 数组 所 有 元 素 赋 值 。 


<html> 
<head> 


<title> 同 时 给 数组 所 有 元 素 赋值 例子 </title> 


</head> 


$string=array( 
"string1", 
"string2", 
"string3", 
"string4", 
"string5" 
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X // 定 义 一 个 数组 同时 给 数组 所 有 元 素 赋值 
for($i=0;$i<count($string);$i++) // 循 环 读 取 数 组 内 容 


{ 

echo $string[$i]; // 显 示 数 组 元 素 
echo "<br>"; /输出 HTML 换行 符 
} 

?> 

</body> 

</html> 


3-6.php: 单独 给 数组 每 个 元 素 赋值 。 


<html> 
<head> 
<title> 分 别 给 数组 每 个 元 素 赋值 例子 </title> 


$string[0]="string1"; // 定 义 数 组 给 数组 每 个 元 素 单独 赋值 
$string[1]="string2"; 

S$string[2]="string3"; 

$string[3]="string4"; 

$string[4]="string5"; 

for($i=0;$i<count($string); $i++) /| 循环 读 取 数组 内 容 


{ 

echo $string[$i]; // 显 示 数 组 元 素 
echo "<br>"; // 输 出 HTML 换行 符 
} 


?> 
</body> 
</html> 


在 PHP 运行 环境 中 分 别 运行 以 上 两 个 例子 ， 输 出 的 结果 都 是 一 样 的 ， 如 图 3.5 所 示 。 


轨 分别 扒 下 久 每 个 元 来 赋 俏 例 于 Wieresefo TE] 
(zno sao sEV ew IAD mwa | 
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图 3.5 给 数组 赋值 执行 结果 


3.4.2 ”获取 数组 中 的 元 素 


在 给 一 个 数组 赋值 之 后 就 可 以 拿 来 使 用 了 。 使 用 的 方法 也 很 简单 。 只 需 使 用 数组 加 上 括号 加 所 需 
要 元 素 的 序号 就 可 以 了 。 需要 注意 的 是 , 数组 下 标 是 从 “0” 开 始 的 ,引用 就 把 需要 引用 的 序号 减 “1”。 
如 “S$String[2]”， 就 实现 了 对 数组 “S$String” 第 3 个 元 素 的 引用 。 下 面 能 过 一 个 简短 的 例子 来 说 明 ， 
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怎样 实现 对 数组 的 引用 。 


<html> 
<head> 
<title> 引 用 数组 元 素 例子 </title> 


S$string=array( 

"string1", 

"string2", 

"string3", 

"string4", 

"string5" 

>; /定义 一 个 数组 

echo "数组 的 第 3 个 元 素 为 :"; 

echo $string[2]; // 获 取 数 组 第 3 个 元 素 
echo "<br>"; 

echo "数组 的 第 5 个 元 素 为 : "; 

echo $string[4]; // 获 取 数 组 第 5 个 元 素 
echo "<br>"; 

echo "数组 的 第 1 个 元 素 为 : "; 

echo $string[0]; // 获 取 数 组 第 1 个 元 素 
?> 

</body> 

</html> 


保存 以 上 代码 为 “3-7.php”。 在 PHP 运行 环境 下 运行 以 上 代码 ， 执 行 结果 如 图 3.6 所 示 。 


BABE Mic 


HANTE st 
数组 的 第 一 个 元 素 为 ，stringl 


El 
图 3.6 引用 数组 元 素 例子 输出 结果 


i EE 


3.4.3 ”给 数组 动态 增加 元 素 


一 个 数组 在 定义 后 ， 它 的 元 素 个 数 并 不 是 一 成 不 变 的 ， 程 序 在 运行 中 可 以 动态 为 数组 增加 元 素 。 
要 给 一 个 数组 动态 增加 元 素 ， 所 要 做 的 只 是 给 数组 新 的 元 素 赋值 。 下 面 仍 然 通 过 例子 来 说 明 这 一 问题 。 


<html> 

<head> 

<title> 动 态 给 数组 增加 元 素 例子 </title> 
</head> 

<body> 

<? 

S$string=array( 
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"string1", 

"string2", 

"string3", 

"string4", 

"string5" 

六 /定义 一 个 数组 
echo "数组 的 第 三 个 元 素 为 : "; 

echo $string[2]; // 获 取 数 组 元 素 
echo "<br>"; 

echo "数组 的 第 五 个 元 素 为 : "; 

echo $string[4]; 

echo "<br>"; 

echo "数组 的 第 一 个 元 素 为 :"; 

echo $string[0]; 

echo "<br>"; 

$string[5]="string6"; /为 数组 动态 增加 元 素 
$string[6]="string7"; /为 数组 动态 增加 元 素 
echo "下 面 的 是 新 增加 的 数组 元 素 : <br>"; 

echo "数组 的 第 六 个 元 素 为 :"; 

echo $string[5]; 1/ 获取 新 增加 的 元 素 
echo "<br>"; 

echo "数组 的 第 七 个 元 素 为 :"; 

echo $string[6]; 

?> 


</body> 


</html> 


保存 以 上 代码 为 “3-8.php”。 在 PHP 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 3.7 所 示 。 


3 动 雯 零 则 组 增 加 元 去 例子 一生 cr 
| 文件 到 MAD 查看 WD CAW IR; 


数组 的 第 三 VEEE string3 四 
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的 : 为 ，strine6 
孝 组 的 第 十 个 元 素 为 ， string7 
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3.7 动态 给 数组 增加 元 素 例子 执行 结果 


3.4.4 创建 多 维 数组 


一 维 数组 的 格式 是 Array[]， 二 维 数组 的 格式 就 是 Array[][]， 多 维 数组 的 格式 是 Array A 
一 维 数组 一 样 ， 给 多 维 数组 赋值 也 有 两 种 方法 。 下 面 分 别 通过 实例 来 具体 说 明 。 

先 来 了 解 一 下 同时 给 多 维 数组 所 有 元 素 赋值 。 下 面 的 实例 要 完成 的 功能 是 在 定义 数组 同时 ， 给 数 
组 所 有 元 素 赋值 。 

<html> 


<head> 


<title> 同 时 给 多 维 数组 所 有 元 素 赋值 例子 </title> 
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</head> 
<body> 

<? 
$string=array( 
0=>array( 

0, 
1, 
2 
ya 
1=>array( 
"string1", 
"string2", 
"string3", 
"string4", 
)， 
2=>array( 
"你 好 !"， 
"大 家 好 ,"， 
" 才 是 真 的 好 " 


) 
> // 创 建 二 维 数组 ， 数 组 元 素 也 是 数组 


for($i=0;$i<count($string);$i++) 
{ 
for($j=0;$j<count($string[$1]); $j++) 


echo $string[$il[$j]; 


// 通 过 循环 读 取 外 层 数 组 内 容 
// 通 过 循环 读 取 内 层 数组 内 容 


// 显 示 数 组 元 素 


</body> 
</html> 


保存 以 上 代码 为 “3-9.php” 在 PHP 执行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 3.8 所 示 。 
xl 
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0,1,2, 
strinel, string2, string3, string4, 
你 好 | ,大 家 好 ，, 才 是 真 的 好 , 
到 


El ET 
图 3.8 同时 给 多 维 数组 所 有 元 素 赋值 例子 执行 结果 
下 面 再 来 介绍 如 何 单独 给 数组 每 个 元 素 赋值 ， 请 参看 以 下 代码 : 


<html> 

<head> 

<title> 单 独 给 多 维 数组 每 个 元 素 赋值 例子 </title> 
</head> 

<body> 


Ck 
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<? 

$string[0][0]=0; /| 单独 给 多 维 数组 每 个 元 素 赋值 
$string[Ol[1]=1; 
$string[0][2]=2; 
$string[1][0]="string1"; 
$string[1][1]="string2"; 
S$string[1][2]="string3"; 
$string[1][3]="string4"; 
$string[2][0]=" 你 好 !"; 
$string[2][1]=" 大 家 好 ，"; 
$string[2][2]=" 才 是 真 的 好 "; 


for($i=0;$i<count($string); $i++) // 通 过 循环 读 取 外 层 数组 内 容 
{ 
for($j=0;$j<count($string[$i]);$j++) // 通 过 循环 读 取 内 层 数组 内 容 
{ 
echo $string[$il[$j]; // 显 示 数 组 元 素 
echo "," 
} 
echo "<br>": 
3 
?> 
</body> 
</html> 


保存 以 上 代码 为 “3-10.php” 在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 和 图 3.8 一 样 。 尽管 以 上 
两 例 数组 赋值 所 采用 的 方法 不 同 ， 但 都 达到 了 给 多 维 数组 赋值 的 目的 。 


3.5 本 章 小 结 


本 章 主 要 介绍 了 PHP 中 的 常量 与 变量 。 并 详细 说 明了 常量 的 定义 与 使 用 、PHP 中 的 预定 义 常 量 ; 
变量 的 类 型 、 变 量 的 使 用 范围 、PHP 的 系统 变量 ;数组 变量 的 初始 化 、 获 取 数 组 中 的 元 素 、 给 数组 动 
态 增 加 元 素 及 多 维 数组 的 创建 与 使 用 等 内 容 。 读 者 在 实际 使 用 时 ， 需 要 注意 以 下 问题 : 

口 常量 与 变量 的 区 别 ， 这 一 点 不 同 于 其 他 编程 语言 。 

口 引用 变量 时 注意 变量 名 的 大 小 写 。 

O 数组 的 引用 形式 ， 这 也 不 同 于 其 他 语言 。 


“ha 


PHP 中 的 运算 符 与 表达 式 
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PHP 中 的 运算 符 

大 种 运算 符 的 优先 级 
PHP Pai 
KUTEUA NGE RA 


š% aa 


运算 符 与 表达 式 是 PHP 中 十 分 重要 的 概念 。 在 PHP 编程 中 ， 表 达 式 是 PHP 程序 
最 重要 的 基石 ， 面 运算 符 又 是 构成 表达 式 的 基础 。 可 以 说 ， 任 何 复 杂 的 PHP 程序 都 是 
由 最 基本 的 运算 符 和 表达 式 组 成 的 。 熟 练 运用 PHP 中 的 运算 符 与 表达 式 ， 是 进行 PHP 
编程 的 基本 功 。 通 过 本 章 学 习 , 读者 将 会 对 PHP 中 的 运算 符 与 表达 式 有 一 个 全 面 的 认识 。 
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PHP 中 的 运算 符 分 为 : 四 则 运算 符 、 逻 辑 运 算 符 、 三 目 运算 符 和 运算 符 的 优先 级 等 。 本 节 将 会 为 
读者 详细 介绍 PHP 中 这 些 运算 符 的 相关 知识 。 


4.1.1 


四 则 运算 符 


数学 运算 符号 有 4 种 ， 包 括 : “+” (加 ) 、“-” ( 减 ) 、 
是 人 们 通常 熟悉 的 符号 ，PHP 中 的 运算 符 基 本 与 此 类 似 ， 只 是 多 一 个 “%” 求 余数 的 符号 。 下 面 通过 
表 4.1 来 具体 介绍 。 


表 4.1 PHP 中 的 四 则 运算 符 


“a” (IR), “P R) 。 这 些 都 


$a 和 $b 的 和 
$a 和 $b 的 差 
$a 和 $b 的 积 
$a 和 $b 的 商 
$a 除 以 $b 的 余数 


在 使 用 “/” 符 号 时 ， 要 注意 求 得 的 商 必定 是 浮 点 数 ， 即 使 能 整除 也 是 这 样 。 另 外 ， 使 用 “%” 符 
号 进行 求 余 运算 时 ， 如 果 除 数 $a 为 负 值 则 结果 也 为 负 值 。 


4.1.2 


逻辑 运算 符 


PHP 中 的 逻辑 运算 符 有 与 、 或 、 异 或 、 非 4 种 。 其 中 的 逻辑 与 和 人 逻辑 或 有 两 种 表现 形式 。 下 面 分 
别 具 体 说 明 。 
and， 逻 辑 与 。$a and $b 两 个 表达 式 求 与 ， 只 有 当 两 个 表达 式 都 为 真 时 返回 True， 和 否则 返回 


日 


口 
口 


口 
口 
口 


False。 


or ZER. Saria 两 个 表达 式 求 或 ， 当 两 个 表达 式 都 为 假 时 返回 False, FRE True. 
xor, ZHR. $a xor $b 两 个 表达 式 求 异 或 。 当 两 个 表达 式 状 态 相 反 时 返回 True， 和 否则 返回 


False。 

L ZHE. $a 一 个 表达 式 求 非 。 当 $a 为 False 时 返回 
&&, Zi. J ande 

|， 逻 辑 或 。 见 or。 


True， 反 之 返回 False。 


之 所 以 “与 ”与 “或 ”有 两 种 表现 形式 〈 逻 辑 与 : and、&&; BER: on D 是 因为 它们 的 运算 
优先 级 不 同 ， 这 一 点 将 在 运算 符 的 优先 级 一 节 (4.1.4 节 ) 中 详细 说 明 。 


下 面 通过 实例 来 说 明 这些 逻 辑 运算 符 是 怎么 用 的 。 由 于 “&&” 等 价 于 “and”， 


所 以 就 不 再 单独 说 明了 。 


示 。 


<html> 
<head> 
<title> 逻 辑 运 算 符 使 用 实例 </title> 


$b=FALSE; 


if($a and $b) echo "这 里 为 假 1! "; 


echo "<br>"; 

if($a or $b) echo "这 里 为 真 1! "; 
echo "<br>"; 

if($a xor $b) echo "这 里 为 真 2! "; 
echo "<br>"; 

if(!$a) echo "XE AR 2!"; 

?> 

</body> 

</html> 
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/定义 逻辑 变量 真 
/定义 逻辑 变量 假 
// 求 与 

// 求 或 

// 求 异 或 


// 求 非 


sj 等 价 于 “or”， 


保存 以 上 代码 为 “4-1.php” 的 PHP 文件 。 在 PHP 执行 环境 中 执行 以 上 代码 ， 执 行 结 果 如 图 4.1 所 


从 图 中 可 以 发 现 ， 以 上 代码 中 只 有 两 名 ECHO 语句 成 功 运行 了 。 下 面 分 析 一 


的 运行 过 程 : 


口 第 1 个 判断 对 一 真一 假 两 项 求 与 。 
口 第 2 个 判断 对 一 真一 假 两 项 求 或 。 
口 第 3 个 判断 对 一 真一 假 两 项 求 异 或 。 
口 第 4 个 判断 对 一 个 真 值 求 非 ， 


下 面 把 以 上 代码 做 如 下 改动 : 


if($a and $b) 改 为 if(!($a and $b))， 把 if(!$a) 改 为 1!$b)。 然 后 再 运行 以 上 代码 ， 运 行 


所 示 。 


4.1.3 


这 里 为 真 11 
这 里 为 真 21 


ea Aa ë 4 


DIRA - Mi eresoit 


XED RED ron TE z” -1 


则 返回 “ 假 ”。 


EEEEIITECECE 


下 以 上 程序 4 个 项 目 


因 两 者 不 同时 为 真 ， 所 以 返回 “ 假 ”。 
因 二 者 有 一 个 为 真 ， 所 以 返回 “ 真 ”。 
因 两 者 状态 不 同 ， 所 以 返回 “ 真 ”。 


结果 如 图 4.2 


soft Tate 


ý 国 

这 里 为 假 11 

这 里 为 直 11 

这 里 为 真 21 

这 里 为 候 2! 
到 加 
yi El A 


4.1 逻辑 运算 符 使 用 实例 执行 结果 


图 4.2 逻辑 运算 符 使 用 实例 执行 结果 


从 以 上 实例 及 改动 后 的 执行 情况 ， 可 以 认识 到 这 些 逻 辑 运 算 符 是 如 何 起 作用 的 。 


三 目 运 算 符 


像 C 语言 一 样 ，PHP 中 也 有 三 目 运 算 符 “?:”。 


它 的 运行 机 制 如 下 : 
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(expr1)?(expr2):(expr3) 


其 中 的 Exprl 、Expr2 及 Expr3 均 为 表达 式 。 当 表达 式 Expr! 为 真 时 则 执行 后 边 的 Expr2， 反 之 则 
执行 Expr3。 从 分 析 中 不 难看 出 ， 三 目 运 算 符 “?:” 实 际 上 也 就 是 f...else 的 简化 版 。 
下 面 通过 一 个 实例 来 说 明 三 目 运算 符 的 使 用 方法 。 


<html> 

<head> 

<title> 三 目 运算 符 使 用 实例 </title> 

<body> 

<? 

$date=Date("D"); // 把 当前 星期 赋值 给 变量 
(($date=="Sun")or($date=="Sat"))?($s=" 周 末 "):($s=" 工 作 "); // 判 断 是 否 是 周末 
echo $s; /显示 状态 

?> 

</body> 

</html> 


保存 以 上 代码 为 “4-2.php”。 在 PHP 执行 环境 下 运行 以 上 代码 ， 如 果 当 前 日 期 的 星期 为 周 六 或 周 
日 时 显示 “休息 ”， 和 否则 显示 “工作 ”。 通 过 这 个 例子 可 以 认识 到 三 目 运 算 符 的 使 用 方法 。 


4.1.4 运算 符 的 优先 级 


在 PHP 中 除了 前 儿 小 节 讲 到 的 常用 运算 符 之 外 ， 还 有 其 他 的 一 些 运算 符 ， 那 么 这 么 多 的 运算 符 ， 
它们 的 优先 级 〈 也 就 是 先 执行 ， 后 执行 的 问题 )》 情 况 是 怎么 样 呢 ? R 4.2 列 出 了 PHP 中 的 运算 符 ， 并 
按 顺序 给 出 了 它们 的 优先 级 。 


表 4.2 PHP 中 运算 符 的 优先 级 


附加 信息 
new 
array() 
++ 一 递增 /递减 运算 符 
! ~- (int) (float) (string) (array) (object) @ 类 型 
算数 运算 符 
算数 运算 符 和 字符 串 运算 符 
位 运算 符 
比较 运算 符 
比较 运算 符 
位 运算 符 和 引用 
位 运算 符 
位 运算 符 
逻辑 运算 符 
逻辑 运算 符 
三 目 运算 符 
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续 表 
附加 信息 
赋值 运算 符 
逻辑 运算 符 
逻辑 运算 符 
逻辑 运算 符 


Wa a 右 联 相反 。 从 上 表 中 可 以 发 现 PHP 中 的 运算 符 有 严格 的 运算 优先 
只 有 搞 清楚 了 它们 的 优先 级 , 才能 正确 得 出 由 运算 符 构 成 的 表达 式 的 值 。 下面 通过 实例 来 说 明 PHP 
heed hp re 


<html> 

<head> 

<title>PHP 运算 符 优先 级 使 用 实例 </title> 

<body> 

<? 

$a=3*4+5%2; BAI 
echo $a."<br>"; 

$a =true?0:true?1:2; // 语 名 2 
echo $a."<br>"; 

$a=1; 

$b=2; 

$a-=$b+=3*$b+$a; // 语 名 3 
echo $a.",".$b."<br>"; 

?> 

</body> 

</html> 


保存 以 上 代码 为 “4-3.php”。 在 PHP 执行 环境 中 运行 以 上 代码 ， 执 行 结果 如 图 4.3 所 示 。 以 上 结 
果 是 怎么 得 出 的 ? 不 管 多 么 复杂 的 表达 式 ， 只 要 按 优 先 级 把 它 分 解 为 简单 的 表达 式 ， 然 后 就 可 以 分 析 
其 结果 了 。 下 面 对 以 上 3 个 语句 逐一 作 分 解 。 

第 1 个 语句 相对 简单 ， 只 用 分 解 为 (3*4)+(5%2) 即 可 。3*4 等 于 12，5 除 以 2 余数 为 1。 所 以 就 是 
12+1 等 于 13。 

第 2 AA 可 以 分 为 两 个 三 目 运算 符 : (true?0:true)?1:2=2。 第 1 个 三 目 运算 符 执 
行 后 前 面 括号 内 容 为 “0”， 而 “0” 相 当 于 False， 所 以 执行 第 2 个 三 目 运算 符 第 2 个 表达 式 。 所 以 就 
有 $a 等 于 2。 

第 3 个 语句 就 有 点 复杂 了 。$a-=$b+=3*$b+S$a 分 解 过 的 式 子 等 价 于 这 样 一 组 表达 式 : 

$b*3 等 于 6，6+$a 等 于 7，$b+7 等 于 9，$b=9，$a-9 等 于 -8，$a=-8。 
通过 分 解 可 以 发 现 输出 的 结果 最 后 Sa=-8、$b=9 是 正确 。 其 执行 过 程 如 图 4.4 所 示 。 

通过 上 面 的 例子 ， 发 现 只 有 掌握 了 PHP 运算 符 的 优先 级 ， 才 能 把 复杂 的 表达 式 转化 为 简单 的 表达 
式 ， 从 而 得 出 表达 式 正确 的 结果 。 


sas PHP 网 络 编程 从 入 门 到 精通 


1-2X3+1+2 
E= 
3 mr 远 复生 基 先 租用 实例 M erosstt AAM E] 6 | 
ZD REU SEV BRO IAT? È 7 
E| 
13 $b=9 
-8,9 
ma 到 
SE WA AI Ia 4 $a=-8 


图 4.3 PHP 运算 符 优先 级 使 用 实例 执行 结果 图 4.4 语句 3 执行 过 程 图 


42 表 达 式 

表达 式 是 PHP 的 基石 ， 在 PHP 程序 中 ,几乎 所 写 的 任何 东西 都 是 一 个 表达 式 。 何 为 表达 式 ? 可 以 
简单 的 说 ， 表 达 式 就 是 “任何 有 值 的 东西 ”。 表 达 式 可 以 为 常量 、 变 量 或 者 函数 。 其 中 常量 和 变量 是 
最 基本 的 表达 式 形式 ， 函 数 是 稍微 复杂 一 点 的 表达 式 形式 。 

例如 下 面 的 函数 : 

<? 

function foo() 

return 5; 
} 
?> 


那么 输入 Sc=foo0) 就 相当 于 写 下 $c=5。 函 数 也 是 表达 式 ， 表 达 式 的 值 即 为 它们 的 返回 值 。 
4.2.1 表达 式 中 变量 的 可 能 值 


表达 式 赋值 给 一 个 变量 , 其 中 的 值 可 能 有 PHP 支持 的 4 种 标量 值 (标量 值 不 能 拆 分 为 更 小 的 单元 ， 
和 数组 、 对象 不 同 ) 类 型 : 整 型 值 (Integer), 浮 点 数值 (Float), 字符 串 值 (String) 和 布尔 值 (Boolean) , 
还 包括 两 种 复合 类 型 〈 数 组 和 对 象 ) 。 所 以 表达 式 的 可 能 值 为 PHP 中 所 有 的 变量 类 型 。 


4.2.2 ”赋值 表达 式 的 值 


一 个 赋值 表达 式 通 常 涉及 到 两 个 值 ， 如 $a=3。 这 样 一 个 表达 式 涉及 到 整 型 常量 3 的 值 以 及 变量 $a 
的 值 ， 它 也 被 更 新 为 3。 还 有 一 个 赋值 语句 本 身 的 值 。 赋 值 语句 本 身 求 值 为 被 赋 的 值 即 3。 因 而 ， 这 样 
写 “$b=($a=3)” 和 这 样 写 “$a=3;$b=3;” 是 一 样 的 。 因 为 赋值 操作 的 顺序 是 由 右 到 左 的 ， 也 可 以 这 么 
写 “Sb=$a=3”。 

通过 以 上 介绍 知道 ， 赋 值 表达 式 牵 涉 3 个 值 : 赋值 变量 值 、 被 赋 的 常量 值 及 表达 式 自身 的 值 。 
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4.23 ”递增 表达 式 


递增 〈 减 ) 表达 式 是 一 种 比较 特殊 的 表达 式 ， 这 类 表达 式 是 一 个 很 好 的 面向 表达 式 的 例子 。 该 类 
表达 式 有 前 、 后 递增 和 递减 。 本 质 上 来 讲 ， 前 递增 和 后 递增 均 增加 了 变量 的 值 ， 并 且 对 于 变量 的 影响 
是 相同 的 ， 不 同 的 是 递增 表达 式 的 值 。 前 递增 写作 “++Svariable ”， 求 增加 后 的 值 。 后 递增 写作 
“$variablet+”， 求 变量 未 递增 之 前 的 原始 值 。 

举 一 个 例子 来 说 明 这 个 问题 ， 代 码 如 下 : 

<html> 


<head> 
<title>PHP 运算 符 优先 级 使 用 实例 </title> 


$a=3; 
echo “$a=3&nbsp;&nbsp;"; 
echo "++\$a 为 :"; 


echo ++$a; //$a 前 递增 
echo "<p>"; 
$a=3; //$a 重新 赋值 为 3 


echo "'\$a=3&nbsp;&nbsp;"; 

echo \$a++ 为 : "; 

echo $a++; //$a 后 递增 
?> 

</body> 

</html> 


保存 以 上 代码 为 “4-4.php”， 


D MV HV www TAO mho | 禾 | 


$a3 ++4a 为 , 4 


$a=3 $aH+ 为 ,3 


EE COOCOO m 
图 4.5 递增 表达 式 执行 情况 
从 图 4.5 执行 结果 可 以 发 现 前 递增 表达 式 与 后 递增 表达 式 的 值 。 


424 比较 表达 式 


一 个 常用 到 的 表达 式 类 型 是 比较 表达 式 。 这 些 表 达 式 求 值 False 或 True。PHP 支持 > (KF) , >= 
(大 于 等 于 ) ， 一 (等 于 ) ，!= (不 等 于 ) ，< (小 于 ) ，<=( 小 于 等 于 )。PHP 还 支持 全 等 运算 符 = 一 
( 值 和 类 型 均 相同 ) 和 非 全 等 运算 符 !==( 值 或 者 类 型 不 同 ) 。 这些 比 较 表达 式 都 是 在 条 件 判断 语句 (如 

证 语句 ) 中 最 常用 的 ， 通 常 被 当 作 条 件 判断 语句 的 判断 条 件 。 
如 变量 $a 的 值 为 3， 变量 $b 的 值 为 4。 则 表达 式 $a< (小 于 ) $b 的 值 就 为 真 。 因 为 3 本 来 就 小 于 4。 
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反之 $a> (KF) $b 的 值 就 为 假 。 
4.2.5 组 合 的 运算 赋值 表达 式 


通过 前 面 对 PHP 表达 式 的 介绍 ， 读 者 知道 如 果 想 要 为 变量 $a 加 1， 可 以 简单 的 写 “$a++” 或 者 
“++$a”。 但 是 如 果 想 为 变量 增加 大 于 1 的 值 如 3， 其 做 法 是 “$a=$a+3”。“$a+3” 计 算 $a 加 上 3 
的 值 ， 并 且 得 到 的 值 重 新 赋予 变量 8a， 于 是 $a 的 值 增加 了 3。 这 个 式 子 还 可 以 用 一 种 更 加 简短 的 形式 
“$at+=3”。 这 里 的 意思 是 “ 取 变量 $a 的 值 加 3， 得 到 的 结果 再 次 分 配给 变量 ga”。 除 了 更 简略 和 清楚 
外 ， 也 可 以 更 快 地 运行 。 

“$a+=3” 的 值 ， 如 同一 个 正常 赋值 操作 的 值 ， 是 赋值 后 的 值 。 注 意 它 不 是 3， 而 是 $a 的 值 加 上 3 
后 的 值 ( 此 值 将 被 赋 给 $a) 。 任 何 二 元 运算 符 都 可 以 用 运算 赋值 模式 ， 例 如 “$a-=5” (从 变量 $a 的 值 
中 减 去 5) ，“$b*=7” (变量 $b 乘 以 7) 等 。 


4.3 运算 符 与 表达 式 综 合 运用 实例 


前 面 两 节 介 绍 了 PHP 中 的 运算 符 与 表达 式 的 相关 知识 。 这 一 节 ， 将 通过 综合 的 例子 来 系统 的 巩固 
4.2 节 所 讲 内 容 。 


<html> 

<head> 

<title>PHP 运算 符 表达 式 综合 运用 实例 </title> 

<body> 

<? 

$a="123"; 

$b=321; 

echo $a+$b; // 字 符 当 数 字 用 
echo "<br>"; 

echo $a.$b; /数字 当 字 符 
echo "<br>"; 

$a=123; 

$b=321; 

echo $b>$a; /比较 大 小 
echo "<br>"; 

echo $a-23+$b+=$a%3?50:30; /三 目 运算 符 与 赋值 四 则 运算 
echo "<br>"; 

$a=123; 

$b=321; 

$a=$b; /赋值 表达 式 
echo $a==$b; 

echo "<br>"; 

?> 

</body> 

</html> 


4. 
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保存 以 上 代码 为 “4-5.php”， 然 后 在 PHP 执行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 4.6 所 示 。 


E) 


444 
123321 
1 
451 
1 
gi 
LE AA 4 


图 4.6 PHP 运算 符 与 表达 式 综合 运用 实例 


上 面 例子 中 的 “$a+$b” 是 实现 了 把 数字 字符 当 作 数 字 使 用 ， 两 数字 相 加 值 为 444。 第 2 句 则 是 实 
现 了 把 数字 当 字 符 用 ， 两 字符 相 加 为 123321。 关 键 就 在 于 使 用 者 用 什么 符号 。 如 果 用 “+”， 就 把 字 
符 当 数字 ;如 果 用 “.” 就 把 数字 当 字 符 。 

第 3 句 是 实现 对 两 个 数字 比较 大 小 。 因 为 321 大 于 123， 所 以 返回 真 值 即 “1”。 

第 4 句 是 三 目 运算 符 与 赋值 运算 符 及 四 则 运算 的 混合 使 用 。$a-23+$b+=$a%3?50:30:; 因 为 数学 运算 
符 遵 循 从 右 到 左 的 标准 ， 而 三 目 运算 符 则 是 从 左 向 右 。 所 以 这 个 表达 式 可 以 分 为 以 下 几 个 子 过 程 。 
$a%3 值 为 “0”， 执 行 三 目 运算 符 “:” 后 的 内 容 ， 返 回 30，$b=$b+30 等 于 351, $a-23=100, 100+351 
等 于 451。 

第 5 句 先 定义 两 个 不 同 的 变量 ， 再 通过 赋值 操作 把 变量 Sb 的 值 赋 给 变量 $8a， 然 后 判断 二 者 是 否 相 
等 ， 在 经 过 赋值 操作 后 ， 二 者 的 值 当然 相等 ， 所 以 比较 结果 返回 真 即 “1”。 


44 本 章 小 结 


这 一 章 主 要 学 习 了 PHP 中 的 运算 符 与 表达 式 。 内 容 包 括 PHP 的 四 则 运算 符 、 罗 辑 运 算 符 、 三 目 运 
算 符 、 运 算 符 的 优先 级 以 及 PHP 中 的 表达 式 。 它 们 的 重要 性 不 言 而 喻 。 正 如 本 章 开头 所 说 的 那样 一 一 
运算 符 与 表达 式 是 PH 最 重要 的 基石 。 所 以 ， 只 有 掌握 了 这 些 内 容 ， 才 能 谈 及 PHP 编程 。 在 实际 运用 
运算 符 及 表达 式 时 要 注意 以 下 儿 个 问题 : 

O ”运算 符 的 优先 级 。 如 果 设 置 不 合理 的 优先 级 ， 得 出 的 就 不 会 是 预想 的 结果 。 

O ”递增 表达 式 的 值 。 从 4-4.php 的 执行 结果 可 以 了 解 到 ， 前 递增 与 后 递增 表达 式 有 不 同 的 值 ， 这 

一 点 需要 引起 注意 。 
口 ”复杂 的 组 合 运算 赋值 表达 式 的 值 。 表 达 式 的 值 为 变量 在 经 过 运算 之 后 的 值 。 


PHP 中 的 流程 控制 


PHP 28 ifi 

PHP 下 的 switch...case 特 断 
PHP 下 的 while 7837 

PHP 下 的 for 783R 

流程 控制 综合 运用 实例 


š š aaa 


无 论 在 何 种 编程 语言 中 ， 流 程控 制 都 是 很 基础 而 且 很 重要 的 内 容 。 由 于 PHP 的 大 
部 分 语法 都 是 继承 了 C 语言 的 将 点 。 因 此 在 流程 控制 方面 ， PHP 有 着 和 C 语言 类 似 的 
流程 控制 。PHP 的 流程 不 像 ASP 那样 可 以 使 用 goto 的 BASIC 语法 。 本 章 将 介绍 PHP 
中 的 判断 与 循环 语句 ,包括 if...else 判断 .Switch...case 多 重 判 新 .while 循环 .do...while 
循环 、for 循环 等 内 容 。 通 过 本 章 的 学 习 将 使 读者 事 握 PHP 流程 控制 知识 ， 为 编写 大 型 
程序 ， 黄 定 坚 实 的 基础 。 


PHP 网 络 编程 从 入 门 到 精通 


5.1 if...else 判断 


站...else 判断 ， 是 流程 控制 中 判断 执行 的 一 种 。 该 语句 执行 时 先 对 某 条 件 进行 判断 ， 然 后 根据 判断 


结果 做 出 相应 的 操作 。 它 又 可 以 详细 地 分 为 3 种 : 简单 的 寺 判 断 、if...else 判断 和 证 ..else...else 判断 。 


本 节 具 体 讲解 证 ..else 判断 。 


5.1.1 简单 的 和 判断 


if 判断 是 流程 控制 中 最 简单 的 一 种 。 只 判断 某 条 件 是 否 为 真 ， 如 果 为 真 就 执行 特定 的 语句 。 例 如 


下 面 这 种 情况 : 


if(expr) 
{ 
statement 


} 


如 果 在 执行 的 statement GH) 多 于 一 句 ， 就 要 使 用 “{}” 把 它们 括 起 来 ， 表 示 一 个 区 段 。 如 果 
要 执行 的 语句 只 有 一 句 ， 就 可 以 省 略 大 括号 标记 。 下 面 通过 一 个 简单 的 例子 来 说 明 如 何 使 用 让 判断 。 


<html> 

<head> 

<title>IF 判断 使 用 实例 </title> 
</head> 

<body> 

<? 


if($cost>100) // 如 果 商 品 的 价格 超过 100 元 执行 操作 


echo " 太 贵 了 ， 不 买 !"; 
?> 

</body> 

</html> 


保存 以 上 代码 为 “5-1.php”。 在 PHP 运行 环境 中 执行 以 上 语句 。 执行 结 果 是 什么 ? 什么 也 没 发 生 。 
这 是 因为 并 没有 定义 一 个 变量 Secost， 没 有 定义 的 变量 就 是 空 值 ， 作 为 数值 就 是 “0”。 而 “0” 是 小 于 
100 的 ， 这 明显 不 符合 让 后 面 的 判断 内 容 〈$cost>100) ， 所 以 什么 也 不 执行 。 这 里 在 让 判断 之 前 加 入 


如 下 一 句 : 

$cost=101; 
再 执行 以 上 代码 ， 结 果 将 会 如 图 5.1 所 示 。 

由 于 此 时 满足 Scost>100 的 条 件 ， 所 以 ff 后 面 的 内 容 会 被 
正确 执行 。 从 这 个 例子 中 能 够 认识 到 if 判断 语句 是 怎么 起 作 
用 的 。 


alo 


ZPO REO FEV KAW IAV 


3 
-| 


ART. FRI 


B 


ase | l T O tet 


4 


5.1 下 判断 使 用 实例 输出 结果 
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5.1.2. if..else 判断 


论 判 断 只 对 判断 结果 为 真 的 情况 执行 操作 ， 这 在 很 多 情况 下 是 不 够 的 。 于 是 就 有 了 证 ..else 这 种 形 
式 的 判断 。 与 让 判断 不 同 ， 让 ..else 不 仅 对 判断 结果 为 真 的 情况 执行 操作 ， 对 非 真 的 情况 也 执行 相应 的 
操作 。 

为 了 简单 说 明 问题 ， 继 续 使 用 5.1.1 小 节 的 例子 ， 只 是 把 5.1.1 小 节 的 例子 做 简单 的 修改 。 具 体 代 
人 码 如 下 : 


<html> 
<head> 

<title>IF…ELSE 判断 使 用 实例 </title> 

</head> 

<body> 

<? 

$cost=101; 

if($cost>100) // 如 果 商 品 的 价格 超过 100 元 执行 操作 
echo " 太 贵 了 ， 不 买 ! "; 

else 

echo "还 挺 便宜 的 ， 就 买 它 吧 ! "; // 如 果 价 格 不 超过 100 元 的 操作 

?> 

</body> 

</html> 


保存 以 上 代码 为 “5-2.php”。 在 PHP 运行 环境 下 执行 以 上 代码 ， 执 行 结果 和 图 5.1 是 完全 一 样 的 。 
因为 $cost 的 值 大 于 100, 所 以 站 语句 结果 为 真 , 跟 在 后 面 的 echo 语句 就 执行 了 , 即 显示 出 不 买 的 信息 。 
把 上 例 中 的 


$cost=101; 
改 为 : 

Sonat | 
重新 执行 以 上 代码 ， 执 行 结果 则 会 如 图 5.2 所 示 。 Kaa, RETE 人 

因为 ， 经 过 改动 Scost 小 于 100， 让 语句 不 再 起 作用 。 而 H 
else 语句 则 起 了 作用 。 所 以 就 会 打印 出 购买 商品 的 信息 。 EE £ 


图 5.2 IF...ELSE 判断 使 用 实例 执行 结果 
5.1.3 if...else...else 多 重 判 断 


虽然 二 ..else 的 判断 比 单纯 的 f 语句 多 了 一 重 判断 ， 但 现实 情况 可 能 还 要 复杂 ， 要 判断 的 情况 会 
超过 两 种 。 如 判断 学 生成 绩 ， 不 能 只 判断 及 格 或 不 及 格 ， 而 要 判断 优 、 良 、 中 、 差 。 这 时 不 管 是 简单 
BI if HK, JE if.. else 判断 都 已 经 不 能 胜任 这 项 工作 了 。 这 时 就 要 用 到 证 ..else...else 的 多 重 判断 。 

if...else...else 多 重 判断 的 使 用 方法 如 下 : 
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if(expr) 
í 


statement 
elseif(expr) 
statement 


elseif(expr) 


statement 


} 


else 


{ 


statement 


} 


它 的 运行 机 制 是 : 先进 行 一 次 判断 ， 如 果 为 真 就 执行 语句 并 跳出 ;否则 再 进行 判断 ， 如 果 为 真 就 
执行 语句 跳出 ;否则 再 进行 判断 …… 直 到 所 有 判断 结束 ， 最 后 剩余 的 情况 ， 再 执行 相应 语句 结束 。 

下 面 通 过 一 个 实例 来 说 明 怎 样 使 用 if...else...else 多 重 判断 。 该 代码 实现 根据 学 生 的 成 绩 ， 来 判断 
其 优 、 良 、 中 、 差 的 级 别 。 


<html> 
<head> 
<title>IF*****" ELSEIF-……| ELSE 多 重 判断 使 用 实例 </title> 


$score=99; 

if($mark>90) // 如 果 成 绩 大 于 90 分 执行 操作 
echo "成 绩 级 别 为 ， 优 !"; 

elseif($score >70) // 如 果 成 绩 在 70~90 之 间 执 行 操作 
echo "成 绩 级 别 为 ， 良 !"; 

elseif($score >60) 

echo "成 绩 级 别 为 ， 中 "; 

else // 如 果 成 绩 低 于 60 执行 操作 
echo "成 绩 级 别 为 ， 差 !"; 

?> 

</body> 

</html> 


保存 以 上 代码 为 PHP 文件 “5-3.php”， 然 后 在 PHP 执行 环境 中 执行 该 文件 。 通 过 改变 $score 的 值 
可 以 看 到 当 值 大 于 90 时 返回 “ 优 ”， 当 值 在 70~ 90 之 间 返 回 “ 良 ”， 当 值 在 60~70 之 间 返 回 “ 中 ”， 
当 值 在 60 以 下 时 返回 “ 差 ”。 通 过 该 例子 ， 能 够 清楚 地 认识 到 IF...ELSEIF...ELSE 多 重 判 断 是 如 何 运 
行 的 。 
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5.2. switch...case 多 重 判断 


多 重 判断 除了 if...else...else 之 外 ， 还 有 另外 一 种 就 是 switch...case。 与 if 43 
switch...case 更 简洁 明了 。switch...case 的 运行 机 制 如 下 : 


switch (expr) { 
case expr1: 
statement1; 
break; 
case expr2: 
statement2; 
break; 


default: 
statementN; 
break; 


i 


expr 通常 是 变量 名 称 ，case 后 的 exprN 通常 为 变量 的 值 ，statementN 为 符合 该 值 时 执行 的 语句 。 
default 为 除 以 上 所 有 判断 之 外 的 情况 ， 最 后 使 用 break 跳出 过 程 。 
下 面 通过 一 个 实例 来 实际 使 用 switch...case。 代 码 如 下 : 


<html> 
<head> 
<title>SWITCH…… CASE 多 重 判断 使 用 实例 </title> 


switch (date("D")) { // 当 前 星期 作为 判断 条 件 

case "Mon": // 星 期 一 的 情况 
echo "星期 一 "; 
break; 

case "Tue": /星期 二 的 情况 
echo "星期 二 "; 
break; 

case "Wed": /星期 三 的 情况 
echo "星期 三 "; 
break; 

case "Thu": // 星 期 四 的 情况 
echo "星期 四 "; 
break; 

case "Fri": /星期 五 的 情况 
echo "星期 五 "; 
break; 


default: // 除 以 上 之 外 的 其 他 情况 
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echo "过 周末 "; 
break; 
y> 
</body> 
</html> 
把 以 上 代码 保存 为 PHP 文件 “5-4.php”， 然 后 在 PHP 运行 环境 下 执行 ， 就 会 返回 中 文 的 星期 。 这 
个 例子 如 果 用 让 来 判断 实现 就 会 比较 复杂 。 从 这 个 例子 能 够 看 出 让 判断 与 switch.…case 的 不 同 。 
在 使 用 switch...case 语句 的 时 候 ， 要 把 出 现 机 率 大 的 情况 放 到 最 前 边 ， 这 样 可 以 提高 程序 执行 效 
率 。 因 为 在 进行 完 一 次 判断 ， 如 果 符合 条 件 ， 执 行 完 相关 语句 就 跳出 整个 过 程 了 。 如 果 把 出 现 机 率 大 
的 情况 放 到 最 后 ， 一 旦 出 现 ， 就 得 执行 完 所 有 判断 ， 这 样 效率 就 低 得 多 。 


5.3 while 循环 


5.1、5.2 节 介绍 了 PHP 流程 控制 中 的 判断 。 从 本 节 开 始 为 读者 介绍 循环 。 循 环 也 是 很 重要 的 一 类 
流程 控制 , 通过 循环 执行 某 些 特定 语句 要 比 多 次 执行 效率 高 。 PHP 中 的 循环 共有 while 循环 、do...while 
循环 和 for 循环 三 大 类 。 这 些 都 将 在 以 后 的 儿 节 中 陆续 为 读者 介绍 。 这 一 节 先 来 学 习 while 循环 。 


5.3.1 单纯 while 判断 循环 


在 循环 控制 中 ， 有 一 种 最 简单 的 循环 模式 ， 即 先 判断 条 件 是 否 符合 特定 要 求 ， 如 果 符合 就 执行 特 
定 操 作 ， 然 后 再 判断 ， 直 到 条 件 不 符合 则 退出 循环 。 但 如 果 一 开始 条 件 就 不 符合 要 求 ， 则 一 次 也 不 执 
行 ， 直 接 跳出 循环 。 这 种 循环 模式 在 PHP 中 的 表现 就 是 while 循环 。while 循环 的 使 用 模式 如 下 : 


while (expr) 


statement 


其 中 的 expr 即 为 特定 的 条 件 ，statement 则 为 执行 的 操作 。 下 面 通 过 一 个 简单 的 例子 来 说 明 While 
循环 的 使 用 方法 。 代 码 如 下 : 


<html> 
<head> 
<title>WHILE 循环 使 用 实例 </title> 
</head> 
<body> 
<? 
$i=1; // 初 始 化 变量 
while($i<10) // 判 断 变 量 是 否 小 于 10 
{ 
echo "第 : ".$i." 次 循环 "; /执行 操作 1 
echo "<br>"; /|! 执 行 操作 2 


$i++; // 变 量 自 增 
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} 

?> 

</body> 

</html> 

保存 以 上 代码 为 “5-5.php”。 在 PHP 运行 环境 上 执行 以 上 代 EIT Err 
码 ， 结 果 如 图 5.3 所 示 。 XO MaD nT ET AD” EE 


程序 先 初始 化 一 个 变量 $i=1， 然 后 再 判断 变量 是 否 小 于 10, 
如 果 小 于 10 就 执行 大 括号 内 的 操作 。 当 然 , 现在 的 变量 小 于 10, 
于 是 就 打印 出 “第 ，1 次 循环 ”， 并 自 增 1， 现 在 变量 值 就 为 2。 
以 此 类 推 当 循 环 执行 到 第 10 次 ， 变 量 值 就 为 10， 而 不 符合 条 件 | 
了 ， 于 是 就 跳出 循环 ， 结 束 整个 过 程 。 DEM Er Zi 

在 使 用 while 循环 时 要 注意 一 个 问题 ， 即 必须 在 while 执行 ”图 5.3 WHILE 循环 使 用 实例 执行 结果 
体 中 使 判断 条 件 的 对 象 有 所 改变 。 如 果 没 有 的 话 就 成 为 死 循环 ， 
而 永 无 止境 了 。 上 例 中 如 果 不 让 变量 自 增 ， 则 变量 的 值 永远 等 于 1， 循 环 就 会 无 休止 地 执行 下 去 ， 直 到 
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5.3.2 ”使 用 break 跳出 循环 


在 使 用 while 循环 时 ， 有 时 并 不 需要 执行 到 满足 while 要 求 的 条 件 。 在 循环 执行 过 程 中 就 可 以 对 执 
行情 况 进行 判断 ， 如 果 满足 某 一 条 件 就 使 用 break 跳出 循环 。 它 的 实现 过 程 如 下 : 


while (expr) 
{ 

statement 
if(expr1) 

$ 


break; 
} 
$ 


break 的 作用 就 是 跳出 当前 循环 。 下 面 举 一 个 例子 来 说 明 ， 还 继续 使 用 5.3.1 小 节 的 代码 ， 但 要 对 
其 做 一 些小 小 的 改动 。 如 下 : 


<html> 

<head> 

<title> 使 用 BREAK 跳出 循环 实例 </title> 
</head> 


$i=1; // 初 始 化 变量 
while($i<10) // 判 断 变 量 是 否 小 于 10 


echo "第 :".$i." 次 循环 "; /! 执 行 操作 1 
echo "<br>"; /| 执行 操作 2 
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$i++; // 变 量 自 增 
if($i==9) // 判 断 变量 情况 
break; // 如 果 满 足 条 件 就 跳出 循环 
} 
?> 
</body> 
</html> 
保存 以 上 代码 为 “5-6.php”， 查 看 以 上 代码 与 5.3.1 小 节 代码 5-5.php 的 不 同 ， 多 出 了 这 样 两 句 。 
if($i==9) 
break; 


E 


执行 结果 会 有 什么 不 同 呢 ? 在 PHP 运行 环境 中 执行 以 A Ji 
上 代码 ， 会 得 到 如 图 5.4 所 示 的 结果 。 

可 以 发 现 ， 与 5.3.1 小 节 的 例子 相 比 ， 少 执行 了 一 次 。 
如 果 没 有 这 $i 一 9) break; 这 样 两 句 ， 程 序 一 直 会 执行 到 
$i<10， 即 当 $i 等 于 9 时 依然 是 满足 条 件 的 。 可 当 使 用 了 没 
有 if($i==9) break; 后 ， 循 环 就 在 $i 等 于 9 时 跳出 了 ， 不 再 KS ET 
执行 。 所 以 看 不 到 第 9 次 循环 。 通 过 这 个 例子 就 可 以 看 到 图 5.4 使 用 BREAK 跳出 循环 实例 执行 结果 
break 是 如 何 起 作用 的 。 

另外 ，break 除了 可 以 运用 到 while 循环 中 之 外 ， 还 能 运用 到 for 循环 以 及 前 面 提 到 的 switch...case 
多 重 判断 中 。 作 用 都 是 跳出 当前 运行 的 过 程 。 


Ame 
E 
si 


5.3.3 ”使 用 continue 语句 


在 循环 结构 中 ，continue 用 来 跳 过 本 次 循环 中 剩余 的 代码 ， 并 在 条 件 求 值 为 真 时 ， 无 条 件 执行 下 一 
次 循环 。 

下 面 通过 一 个 实例 来 说 明 continue 的 工作 原理 。 代 码 仍然 采用 前 几 节 的 代码 ， 只 是 做 少许 改动 ， 
这 样 能 更 明白 地 认识 continue 语句 是 如 何 起 作用 的 。 代 码 如 下 : 


<html> 
<head> 
<title> 使 用 CONTINUE 跳出 本 次 循环 实例 </title> 
</head> 
<body> 
<? 
$i=0; // 初 始 化 变量 
while($i<10) // 判 断 变 量 是 否 小 于 10 
{ 
$i++; // 变 量 自 增 
if($i==5) // 判 断 变 量 情况 是 否 为 5 
{ 


continue; // 如 果 满 足 条 件 就 跳出 本 次 循环 
} 
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echo "第 : "Si" 次 循环 " /| 执行 操作 1 
echo "<br>"; /| 执行 操作 2 

A 

</body> 

</html> 

保存 以 上 代码 为 “5-7.php”。 在 PHP 执行 环境 下 aa aa AA ak 
运行 以 上 代码 ， 执 行 结 果 如 图 5.5 所 示 。 PEP F 

从 图 5.5 中 可 以 看 到 ， 由 于 continue 的 存在 , 第 5 F a 
次 循环 并 没有 被 执行 。 $ eaa 

和 break 一 样 , continue 同样 也 可 以 用 在 while, for, E a 
switch 之 中 ， 其 作用 原理 都 是 一 样 的 。 另 外 ， 在 使 用 H 
continue 时 还 要 注意 的 一 点 是 ，continue 后 面 的 “;” 是 MAZIWA WAA WA ENEA E 

能 省 略 的 。 如 果 省 掉 会 导致 不 希望 的 结果 出 现 图 5.5 使 用 CONTINUE 跳出 本 次 循环 实例 执行 结果 


5.4 do...while 循环 


这 一 节 来 介绍 do...while 循环 。 do.. .While 循环 与 单纯 的 while 循环 不 同 。 单纯 的 while 循环 是 先 判 
Kana 为 真 ， 如 果 为 真 则 执行 , 否则 就 不 执行 循环 。 也 就 是 说 , while 循环 有 可 能 一 次 也 不 执行 ( 初 
始 条 件 是 非 真 的 情况 ) 。 而 ae 循环 则 与 此 不 同 ， 它 是 先 执行 一 次 循环 ， 然 后 再 判断 条 件 是 否 为 
真 ， 如 果 为 真 继续 执行 ， 否 则 就 跳出 循环 。 它 的 执行 模式 如 下 : 

do 


statement 
}while (expr); 


下 面 通过 一 个 实例 来 说 明 do.…while 是 如 何 起 作用 的 。 还 是 使 用 前 几 节 的 代码 ,只 是 作 了 少许 改动 ， 
这 样 可 以 更 清楚 地 了 解 到 它们 之 间 的 异同 。 代 码 如 下 : 


<html> 

<head> 

<title>DO……WHILE 循环 使 用 实例 </title> 

</head> 

<body> 

<? 

$i=1; // 初 始 化 变量 

do // 开 始 执行 循环 
echo": ".$i." 次 循环 "; // 执 行 操作 1 
echo "<br>"; //! 执 行 操作 2 
$i++; // 变 量 自 增 
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while($i<1) // 判 断 变量 是 否 小 于 1 


7> 

</body> 

</html> 

保存 以 上 代码 为 “5-8.php”。 在 PHP 运行 环境 中 执行 以 
上 代码 ， 运 行 结果 如 图 5.6 所 示 。 

如 果 要 是 在 while 循环 中 ， 循 环 肯 定 一 次 也 不 执行 就 退 第 KET 


ET TE = Mi crossit 
文件 中 SED FEV kaw IAQ? I 
c] 


B z 
出 了 。 因 为 变量 $i 的 值 等 于 1， 不 满足 $i<1 的 条 件 。 但 在 KA kaa aa 5 


do...while 循环 中 则 不 然 , 循环 先 执行 一 次 再 判断 ， 由 于 已 经 5.6 DO...WHILE 循环 使 用 实例 输出 结果 
不 满足 条 件 于 是 就 退出 循环 。 


5.5 for 循环 


for 循环 是 PHP 中 最 复杂 的 循环 结构 。 它 的 行为 和 C 语言 相似 。for 循环 的 执行 模式 如 下 : 
for (expr1; expr2; expr3) 
í 


statement 


} 

口 第 一 个 表达 式 exprl 在 循环 开始 前 无 条 件 求 值 一 次 。 

O expr 在 每 次 循环 开始 前 求 值 。 如 果 值 为 Tmue， 则 继续 循环 ， 执 行 statement 语句 。 如 果 值 为 

False， 则 终止 循环 。 

口 expr3 在 每 次 循环 后 被 执行 。 

每 个 表达 式 都 可 以 为 空 。expr2 为 空 意味 着 将 无 限 循环 下 去 。 如 果 expr2 为 空 ， 循 环 无 限 执 行 ， 任 
何 使 用 者 都 不 想 出 现 这 种 结果 , 但 用 户 也 可 以 在 循环 体 里 加 入 break 语句 。 当 某 个 条 件 为 真 时 ， 就 执行 
break 语句 来 跳出 for 循环 。 

下 面 通过 一 个 实例 来 实现 for 循环 。 代 码 如 下 : 

<html> 


<head> 
<title>FOR 循环 使 用 实例 </title> 


for($i=1;$i<10;$i++) /FOR 循环 开始 


echo "第 : ".$i." 次 循环 "; // 要 执行 的 语句 
} 
?> 
</body> 
</html> 
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保存 以 上 代码 为 “5-9.php”。 在 PHP 执行 环境 中 运行 ， 执 行 结果 与 图 5.3 完全 一 样 (除了 HTML 
显示 的 标题 ) 。 

通过 5.3 节 对 while 循环 的 介绍 ， 对 比 本 节 对 for 的 介绍 ， 可 以 发 现 两 者 的 不 同 。 在 实际 应 用 中 ， 
车 循环 有 初始 值 ， 并 且 都 需要 累加 (或 者 累 减 ) ， 这 时 使 用 for 循环 就 比 使 用 while 循环 要 好 。 


5.6 ”流程 控制 综合 运用 实例 


这 一 节 将 通过 一 个 实例 ， 把 判断 与 循环 两 种 方法 结合 起 来 ， 做 一 个 实际 应 用 的 例子 。 通 过 这 个 例 
子 ， 巩 固 本 章 所 学 的 内 容 。 
以 下 例子 实现 的 功能 是 根据 二 维 数组 的 内 容 ， 以 表格 的 形式 分 类 打印 出 数组 的 全 部 内 容 ， 并 以 不 


同 的 背景 颜色 显示 大 类 别 及 小 类 别 。 本 例 代码 如 下 : 


<html> 

<head> 

<title> 流 程控 制 综合 运用 实例 </title> 
<head> 


// 首 先 定义 一 个 数组 


图 书 类 型 数组 


$type[0][0]=" 学 生 用 书 "; // 第 1 个 大 类 别 
$type[0][1]=" 学 生 教 材 "; // 第 1 大 类 中 的 第 1 小 类 
$type[0][2]=" 教 辅 用 书 "; 
$type[0][3]=" 课 外 读物 "; 
$type[0][4]=" 考 试题 集 "; 
$type[1][0]=" 名 著 "; 1/ 第 2 个 大 类 别 
$type[1][1]=" 中 国 古 典 "; // 第 2 大 类 中 的 第 1 小 类 
$type[1][2]=" 世 界 名 著 "; 
$type[1][3]=" 英 文 原著 "; 
$type[2][0]=" 考 试用 书 "; // 第 3 个 大 类 别 
$type[2][1]=" 公 务 员 "; // 第 3 大 类 中 的 第 1 小 类 
$type[2][2]=" 会 计 师 "; 
$type[2][3]=" 医 药师 "; 
$type[3][0]=" 儿 童 读物 "; // 第 4 个 大 类 别 
$type[3][1]=" 看 图 识字 "; // 第 4 大 类 中 的 第 1 小 类 
$type[3][2]=" 动 漫 人 物 "; 
$type[4][0]=" 武 侠 小 说 "; // 第 5 个 大 类 别 
Stype[4][1]=" 金 庸 小 说 "; /人 第 5 大 类 中 的 第 1 小 类 
$type[4][2]=" 古 龙 小 说 "; 
$type[4][3]=" 玄 幻 小 说 "; 
echo "<table border=\"1\">"; 1/ 打印 表格 头 
for($i=0;$i<count($type);$i++) // 外 层 循环 
{ 
$s=0; // 定 义 循环 标识 变量 
for($j=0;$j<count($type[S$i]);$j++) // 内 层 循环 


{ 
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if($s%2==0) echo "<tr>"; 1/ 如果 标 识 为 偶数 新 起 一 行 
$s++; /标识 自 增 
if($j==0) /| 判断 是 否 为 大 类 别 
echo "<td colspan=2 bgcolor=\"#cccc00\">"; ”// 打 印 大 类 别 的 表格 
else echo "<td bgcolor=\"#ccccff\">"; 1/ 打印 小 类 别 的 表格 
echo $type[$i[$j; /| 输出 数据 
echo "</td>"; /表格 结束 
if($j==0) // 判 断 是 否 为 大 类 别 
{ 
$s++; // 如 果 为 大 类 别 则 标识 再 次 自 增 
} 
if($s%2==0) echo "</tr>"; // 如 果 大 类 别 一 格 或 小 类 别 两 格 则 表格 的 地 行 结束 


if($s==(count($typel$i])+1) && count($type[$i)%2==0)// 判 断 小 类 别 项 为 奇数 的 情况 
echo "<td bgcolor=\"#ccccfh">&nbsp;</td></tr>";// 在 后 面 添 加 空 表格 


} 


p> ER 
< > 二 
把 以 上 代码 保存 为 PHP 文件 “5-10.php”。 在 Wa 

PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 5.7 RE 

所 示 。 BAR E 
这 个 例子 中 的 流程 控制 比较 复杂 ， 要 考虑 多 种 -一 一 一 

情况 。 如 大 类 别 只 占 一 格 的 情况 、 小 类 别 占 两 格 的 ERAF READ 

情况 、 小 类 别 结尾 不 足 两 格 的 情况 等 。 通 过 这 个 例 ENA EANA 

子 ， 把 本 章 学 到 的 判断 、 循 环 的 知识 都 运用 到 里 面 aa. É 

了 。 同 时 也 使 读者 了 解 到 ， 在 使 用 PHP 编程 时 ， -人 一 

如 何 使 用 流程 控制 来 处 理 复杂 的 问题 。 图 5.7 流程 控制 综合 运用 实例 执行 结果 
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流程 控制 是 PHP 编程 的 基础 , 很 多 算法 的 设计 都 要 考虑 到 流程 控制 。 这 一 章 学 习 了 PHP 中 的 流程 
控制 ， 具 体内 容 包 括 if 判断 、switch...case 多 重 判 断 、while 循环 、do...while 循环 、for 循环 等 内 容 。 
通过 本 章 的 学 习 使 读者 掌握 PHP 流程 控制 知识 ， 为 编写 大 型 程序 葛 定 坚实 的 基础 。 


什么 是 函数 
函数 的 参数 

PaE sd- BHAA- 

PHP PRAHARA 
作用 自 定义 函数 


aa aaa 


函数 是 PHP 最 重要 的 组 成 部 分 。 如 果 说 前 几 章 介绍 的 变量 、 表 达 式 、 流 程控 制 是 
PHP 的 基础 的 话 ， 那 么 可 以 说 函数 就 是 PHP 的 主体 。 什 么 是 函数 呢 ? 简单 的 说 ， 函 数 
就 是 为 了 完成 将 定 功能 而 作为 一 个 整体 存在 的 代码 块 。PHP 中 有 大 量 的 库 函 数 ， 同 时 
也 允许 用 户 自 定义 函数 。 本 章 就 带领 读者 来 认识 一 下 函数 。 本章 内 容 包 括 : 什么 是 函数 、 
函数 的 参数 、 函 数 的 返回 值 、PHP 内 部 函数 的 使 用 、PHP 加 载 外 部 函数 、 如 何 自 定义 
函数 等 。 
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6.1 什么 是 函数 


简单 的 说 ， 函 数 是 为 了 完成 特定 功能 ， 而 作为 一 个 整体 存在 的 代码 块 。 例 如 ， 求 绝对 值 函数 abs() 
完成 的 功能 是 求 一 个 数 的 绝对 值 ， 而 且 它 也 是 独立 存在 的 ， 并 不 受 其 他 变量 或 函数 的 影响 。 函 数 采用 
以 下 方法 来 定义 。 
function f name($arg) 
{ 
expr; 
return $retval; 


} 


以 上 代码 中 人 name 为 函数 名 ， 以 名 字 来 区 别 其 他 函数 。$arg 为 函数 的 参数 ， 参 数 是 在 函数 执行 中 
要 传递 的 值 ， 它 跟 在 函数 后 面 的 括号 里 。 如 果 要 求 “-3 ”的 绝对 值 就 要 用 参数 来 传递 “-3”, 如 abs(-3)。 
expr 为 函数 执行 的 语句 ，$revel 为 函数 的 返回 值 ， 返 回 值 并 不 是 每 个 函数 都 有 。 返 回 值 指 完成 函数 后 返 
回 到 主 程序 中 的 值 。 如 abs(-3) 的 返回 值 为 “-3” 的 绝对 值 “3”。 其 中 函数 名 的 命名 规则 与 PHP 中 的 
变量 命名 规则 相同 。 有 效 的 函数 名 以 字母 或 下 划 线 打头 ， 后 面 跟 字 母 ， 数 字 或 下 划 线 。 

在 PHP 3 中 一 个 函数 在 调用 之 前 必须 已 经 被 初始 化 。 如 果 调用 一 个 未 被 定义 的 函数 ， 将 会 导致 错 
误 。 从 PHP 4 开始 ， 就 不 再 有 这 种 限制 ， 这 意味 着 可 以 先 调用 一 个 并 未 被 定义 的 函数 ， 然 后 再 去 定义 
函数 。 但 是 如 果 函 数 的 定义 是 有 条 件 的， 那么 在 这 有 条 件 的 定义 发 生前 ， 是 不 能 被 调用 的 。 就 像 下 面 
这 两 种 情况 。 


1. 有 条 件 的 定义 

具体 内 容 请 参看 以 下 代码: 

<? 

$makefoo=true; 

/不 能 在 这 里 调用 函数 foo 

因为 它 现在 并 不 存在 

但 是 可 以 调用 函数 bar*/ 

bar(); // 调 用 函数 bar 

if($makefoo) /定义 函数 据 条 件 
function foo() /定义 函数 foo 

echo "| don't exist until program execution reaches me.\n"; // 输 出 字符 串 

$ 

} 

/现在 可 以 调用 函数 foo T, 

因为 它 已 经 被 定义 */ 

if ($makefoo) foo(); // 调 用 函数 foo 

function bar() // 无 条 件 定义 函数 bar 


t 
echo "| exist immediately upon program start.\n"; 
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} 

?> 

以 上 为 第 1 种 情况 ， 虽 然 定义 函数 的 条 件 为 真 ， 但 是 在 有 条 件 的 定义 前 ， 函 数 是 不 能 被 调用 的 。 
即 如 果 某 条 件 为 真 则 再 去 考虑 是 否 去 做 某 件 事 ， 如 果 这 条 件 根本 不 存在 ， 就 不 考虑 去 做 这 件 事 ， 更 不 
用 说 怎么 去 做 了 。 

这 里 举 一 个 形象 的 例子 。 例 如 ， 一 个 家 长 叫 小 孩子 去 买 东西 。 小 孩子 如 何 去 买 东西 可 以 看 作 是 一 
个 函数 。 但 是 小 孩 也 给 家 长 提 了 条 件 ， 如 果 给 1 元 辛苦 费 才 去 买 。 即 只 有 满足 了 给 1 元 钱 的 条 件 ， 才 
去 执行 买 东西 这 个 函数 ， 也 才 去 考虑 怎么 去 买 。 如 果 条 件 根本 不 存在 ， 那 么 函数 就 相当 于 没有 定义 ， 
当然 也 不 会 执行 了 。 

2 函数 的 苦 套 定义 

第 2 种 情况 是 在 某 一 函数 体 中 定义 另 一 个 函数 。 只 有 当 外 层 函 数 被 调用 时 ， 内 层 函数 才 会 被 正确 
定义 。 所 以 也 只 有 在 调用 外 层 函 数 后 ， 才 能 调用 内 层 函 数 。 示 例如 下 : 

<? 

function foo() 


function bar() 
{ 


} 


} 

MNA MAMA ER bar 
因为 它 还 未 被 定义 */ 
foo(); 
/现在 可 以 调用 函数 bar 
因 随 着 函数 foo 的 调用 
函数 bar 也 被 正确 定义 了 */ 
bar(); 

?> 


echo "| don't exist until foo() is called.\n"; 


这 种 情况 也 很 容易 理解 ， 与 第 1 种 情况 存在 某 些 相似 之 处 。 只 是 把 定义 函数 的 条 件 转化 为 了 某 一 
函数 的 执行 。 

如 果 不 把 上 面 比方 的 例子 中 的 家 长 给 钱 看 成 一 个 条 件 ， 而 是 一 个 函数 ， 就 变 成 了 第 2 种 函数 的 嵌 
套 定义 了 。 即 家 长 给 钱 的 函数 执行 了 ， 那 么 孩子 去 买 东西 这 个 函数 就 会 被 定义 ， 然 后 就 可 以 调用 函数 ， 
如 怎么 去 买 东西 了 。 

另外 在 使 用 函数 时 还 有 一 点 需要 注意 .与 变量 不 同 , 函数 是 大 小 写 不 敏感 的 ,如 定义 的 函数 为 bar()， 
实际 使 用 时 完全 可 以 通过 bar0 来 调用 它 。 但 通常 情况 下 , 为 了 避免 混淆 ,调用 时 还 是 使 用 定义 时 的 名 字 。 


6.2 ”函数 的 参数 


在 6.1 节 介绍 函数 的 定义 中 ， 提 到 了 函数 的 参数 : 
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function f name($arg) 
{ 

expr 

return $retval; 


以 上 代码 中 的 $arg 就 是 一 个 参数 。 那 么 究竟 什么 是 函数 的 参数 ? 

PHP 中 的 函数 按 有 无 参数 可 分 为 : 有 参数 函数 和 无 参数 函数 两 种 。 函 数 参 数 只 存在 于 有 参数 的 函 
数 之 中 。 函 数 参数 就 是 函数 名 称 后 圆 括号 内 的 常量 值 、 变 量 、 表 达 式 或 函数 。 当 定义 函数 时 ， 这 时 的 
参数 因为 无 实际 值 ， 所 以 称 其 为 形式 参数 ， 形 式 参 数 不 能 是 常量 值 。 当 调用 该 函数 时 ， 这 时 的 参数 有 
实际 的 值 称 为 实际 参数 。 形 式 参数 的 类 型 说 明 在 函数 名 后 的 “0” 之 内 。 

下 面 通过 一 个 简单 的 例子 来 说 明 函 数 参数 的 使 用 。 


<html> 

<head> 

<title> 函 数 参数 的 使 用 实例 </title> 

</head> 

<body> 

<? 

function B | tert($tert) /定义 有 参数 函数 

echo "<b><i>". $text."</i></b>"; // 打 印字 符 并 加 入 粗 体 斜 体 效果 

} 

$string="PHP 编程 是 一 件 很 简单 的 事情 "; // 定 义 变量 

echo $string; // 打 印 变量 

echo "<br>"; 

B_|_text($string); // 用 实际 参数 调用 函数 

?> 

</body> 

</html> 

保存 以 上 代码 为 “6-1.php”。 在 PHP 执行 环境 中 运行 该 代码 ， 执 行 结果 如 图 6.1 所 示 。 

上 例 中 , 先 定义 了 有 形式 参数 的 函数 。 然 后 定义 变量 ， KANE miest m 
先 显示 变量 ， 再 通过 实际 参数 调用 函数 。 从 这 个 例子 中 ， ee mot 
读者 可 以 了 解 到 函数 的 参数 是 如 何 传递 值 到 函数 体 的 。 maa | 

在 使 用 函数 参数 时 还 应 该 注意 一 个 问题 。 函 数 的 参数 EE CO Bi 4 


是 有 类 型 限制 的 ， 即 某 一 函数 的 参数 可 能 只 对 应 某 一 种 类 图 6.1 函数 参数 的 使 用 实例 执行 结果 
型 。 如 果 参 数 的 类 型 与 函数 要 求 的 类 型 不 一 致 ， 就 会 发 生 
错误 ， 可 能 会 返回 用 户 不 希望 的 结果 。 如 abs() 函 数 的 作用 是 计算 一 个 数 的 绝对 值 ， 所 以 它 的 参数 只 能 
为 整 型 或 者 浮 点 型 数 。 如 果 用 字符 或 者 数组 作为 函数 的 参数 ， 则 一 定 会 出 现 用 户 不 希望 的 结果 。 
另外 ， 有 的 函数 有 默认 的 值 的 参数 。 这 时 的 参数 就 变 成 了 可 选 参数 ， 即 调用 该 函数 时 可 以 不 加 有 
默认 值 的 参数 。 函 数 将 用 默认 值 来 替换 该 参数 。 下 面 举 一 个 例子 来 说 明 : 
<html> 


<head> 


<title> 函 数 有 默认 值 参数 的 使 用 实例 </tile> 
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function B_l_text($text,$color="#000000") 


/定义 有 参数 函数 ， 其 中 $color 参数 有 默认 值 


{ 
echo "<font color=".$color.">"; 
/使 用 颜色 参数 
echo "<b><i>". $text."</i></b>"; 
// 打 印字 符 并 加 入 粗 体 斜体 效果 
echo "</font>"; 
} 
$string="PHP 编程 是 一 件 很 简单 的 事情 "; /定义 变量 
echo $string; 1/ 打印 变量 
echo "<br>"; 
B | tert($string); // 调 用 函数 ， 无 $color 参数 
Echo "<p>"; 
Bi text($string,"red"); // 调 用 函数 ， 加 入 $color 参数 
?> 
</body> 
</html> 

保存 以 上 代码 为 “6-2.php”。 在 PHP 执行 环境 中 运行 该 文件 ， 执 行 结果 如 图 6.2 所 示 。 

上 例 先 定义 了 一 个 有 两 个 参数 的 函数 ， 其 中 的 $color ais 
参数 有 默认 值 . 即 当 调 用 函数 时 , 如 果 不 加 可 选 参数 Scolor， uume ma 
将 使 用 默认 值 “#000000”， 即 用 黑色 打印 字体 。 所 以 第 1 ama EN 
次 调用 该 函数 时 没有 使 用 $color 函数 ， 打 印 出 的 字体 是 黑 PERET HIMALIA 加 
色 的 。 第 2 次 调用 时 使 用 了 “red” 作 为 $color 参数 ， 则 打 II II £ 
印 出 的 字体 就 是 红色 的 。 图 6.2 ”函数 有 默认 值 参数 的 使 用 实例 执行 结果 


6.3 函数 的 返回 值 


在 6.1 节 讲 到 函数 时 ， 同 时 也 提 到 了 函数 的 返回 值 。 


function f name($arg) 
{ 


expr; 
return $retval; 
} 


即 以 上 代码 中 的 $retval。 函 数 通 过 return 来 返回 值 。 函 数 的 返回 值 可 以 是 数值 、 字 符 等 变量 。 下 面 
通过 一 个 实例 来 说 明 函 数 的 返回 值 是 如 何 使 用 的 。 
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<html> 
<head> 
<title> 函 数 返 回 值 的 使 用 实例 </title> 
</head> 
<body> 
<? 
function cube($num) // 定 义 有 参数 函数 
{ 
return $num*$num*$num; // 将 参数 连 乘 三 次 的 值 作为 返回 值 
} 
$i=3; 
echo $i." 的 三 次 方 为 :".cube($i); // 有 实际 参数 调用 函数 
?> 
</body> 
</html> 
保存 以 上 代码 为 “6-3.php”。 在 PHP 执行 环境 中 运 EEEEEIITTEDETETTET alala 
行 以 上 代码 ， 执 行 结果 如 图 6.3 所 示 。 ERU eta ERE eta RD LE 
3 的 三 次 方 为 ，27 
另外 , 函数 不 能 有 多 个 返回 值 , 但 是 为 了 返回 多 个 值 ， | i 
可 以 将 数组 作为 一 个 函数 的 返回 值 , 从 而 实现 多 个 值 的 返 三 这 4 
回 。 下面 通过 一 个 实例 来 说 明 , 函数 是 如 何 将 一 个 数组 作 图 6.3 函数 返回 值 使 用 实例 执行 结果 
为 其 返回 值 的 。 
<html> 
<head> 
<title> 函 数 将 数组 返回 值 的 使 用 实例 </title> 
</head> 
<body> 
<? 
function E_num($num1,$num2) /定义 函数 有 两 个 参数 
i 
if($num1>$num2) // 如 果 前 面 数 大 两 者 互 换 
{ 
S$temp=$num1; 
$num1=$num2; 
$num2=$temp; 
} 
for($i=$num1;$i<$num2;$i++) /1 循环 比较 两 数 之 间 的 值 
if($i%2==0) // 选 出 其 中 的 偶数 
St[$)]=$i; // 把 结果 赋值 给 数组 元 素 
$j++; 
} 
} 
return $t; /把 数组 $t 作为 函数 返回 值 


} 
$a=3; /定义 变量 
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$b=20; 

$c=E_num($a,$b); // 调 用 函数 
echo $a." 到 ".$b." 之 间 的 偶数 为 : "; 

for($i=0;$i<count($c);$i++) /遍历 数组 
{ 


echo $c[$]; /显示 结果 
echo "<br>"; 
} 
?> 
</body> 
</html> 
上 面 代 码 定义 了 一 个 函数 E_num(int numl,int 
num2)， 它 的 作用 是 求 出 两 个 数 之 间 所 有 的 偶数 。 因 
为 两 数 之 间 的 偶数 可 能 为 多 个 数 ， 所 以 要 返回 多 个 数 
值 。 这 就 要 在 函数 中 把 这 些 数值 定义 到 数组 中 ， 然 后 
把 数组 当 作 函 数 的 返回 值 返回 。 
把 以 上 代码 保存 为 “6-4.php”。 在 PHP 执行 环境 
中 运行 以 上 代码 ， 执 行 结果 如 图 6.4 所 示 。 
函数 的 返回 值 部 分 ， 这 一 节 就 介绍 到 这 里 。 相 信 6A 函数 将 数组 返回 值 的 使 用 实例 执行 结果 
通过 上 面 的 几 个 例子 ， 对 函数 的 返回 值 的 讲解 ， 读 者 会 有 一 个 深刻 的 印象 。 


A O ES 


6.4 PHP 内 部 函数 的 使 用 


PHP 为 用 户 提供 了 丰富 的 库 函 数 即 内 部 函数 ,能 否 熟 练 的 使 用 PHP 的 内 部 函数 ， 是 衡量 一 个 PHP 
程序 员 合格 与 否 的 标准 。 那 么 如 何 使 用 PHP 中 的 库 函 数 呢 ? 由 于 内 部 函数 是 集成 在 PHP 解释 器 中 的 ， 
所 以 它 不 用 被 定义 ， 可 以 直接 使 用 。 使 用 时 只 是 要 注意 函数 的 参数 类 型 、 调 用 方法 、 返 回 值 及 格式 即 可 。 

相对 于 用 户 自 定义 函数 来 说 ，PHP 的 内 部 函数 使 用 更 简单 。 一 是 因为 它 不 用 定义 ; 二 是 不 用 担心 
函数 体 本 身 会 出 错 。 如 果 在 使 用 库 函 数 时 返回 了 不 希望 出 现 的 结果 ,那么 不 要 怀疑 是 系统 函数 有 问题 。 
因为 这 些 函 数 都 是 经 过 了 反复 的 实践 证 明 的 ， 是 绝对 正确 无 误 的 。 

下 面 就 通过 两 个 例子 ， 来 说 明 在 PHP 中 如 何 使 用 库 函 数 。 

调用 常用 的 数学 函数 。 

<html> 

<head> 


<title>PHP 库 函 数 的 使 用 实例 1</title> 


</head> 


echo abs(-3); // 调 用 求 绝对 值 的 库 函 数 
echo "<p>"; 

echo floor(5.321); // 调 用 取 整 函数 

echo "<p>"; 
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echo pi(); // 调 用 圆周 率 函 数 

echo "<p>"; 

echo min(5,1,3,7,8); // 调 用 求 最 小 值 函数 

echo "<p>"; 

echo max(5,1,3,7,8); // 调 用 求 最 大 值 函数 

?> 

</body> 

</html> IPMERRHEEEANI - Microsef Taasi 
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保存 以 上 代码 为 “6-5.php”。 在 PHP 执行 环境 中 运 本 

行 以 上 代码 ， 执 行 结果 如 图 6.5 所 示 。 5 
调用 数组 函数 。 3. 1415926535898 


1 


<html> 
<head> 2 
<title>PHP 库 函 数 的 使 用 实例 2</title> E A E zA 


图 6.5 PHP 库 函 数 的 使 用 实例 1 执行 结果 


8 


print_r(array_count_values ($a)); 

?> 

</body> 

</html> 

将 以 上 代码 保存 为 “6-6.php”。 在 PHP 执行 环境 中 IrORERMEARA Microsoft Internat Tapiaren T P =f] 
运行 以 上 代码 ， 执 行 结果 如 图 6.6 所 示 。 ———.... 

从 上 两 个 例子 中 可 以 看 出 ，PHP 的 库 函数 有 的 需要 Wa MA 
参数 ， 有 的 不 需要 参数 ， 有 的 还 需要 多 个 参数 。 所 以 在 BEJ SARASA 3 
使 用 函数 前 ， 了 解 该 函数 的 使 用 方法 是 很 有 必要 的 。 本 图 6.6 PHP 库 函数 的 使 用 实例 2 执行 结果 
书 将 在 以 后 章节 中 专门 讲解 相关 的 函数 使 用 方法 。 


6.5 PHP 加 载 外 部 函数 


PHP 有 很 多 库 函 数 ， 还 有 一 些 函 数 需要 和 特定 的 PHP 扩展 模块 一 起 编译 ， 否 则 在 使 用 它们 的 时 候 
就 会 得 到 一 个 致命 的 “未 定义 函数 ”错误 。 例 如 ， 要 使 用 图 像 函 数 如 imagecreatetruecolor()， 就 需要 在 
编译 PHP 的 时 候 加 上 对 GD 库 的 支持 。 具 体 作法 就 是 修改 php.ini 文件 。 找 到 这 一 行 : 
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;extension=php_gd.dll 


把 这 一 行 行 首 的 “;” 去 掉 ， 这 样 PHP 解释 器 在 启动 时 就 会 加 载 GD 库 函 数 ， 然 后 就 可 以 像 使 用 内 
部 库 函 数 一 样 使 用 GD 库 函 数 。 

对 其 他 外 部 函数 的 使 用 也 是 如 此 ， 要 使 用 相应 的 函数 ， 就 要 先 加 载 相应 的 模块 。 有 很 多 核心 函数 
已 包含 在 每 个 版 本 的 PHP 中 ,如 字符 串 和 变量 函数 等 。 调 用 Phpinfo() 函 数 ， 可 以 了 解 到 PHP 加 载 了 哪 
些 扩展 库 。 同 时 还 应 该 注意 ， 很 多 扩展 库 默认 就 是 有 效 的 。 

下 面 通过 一 个 实例 ， 来 说 明 如 何 加 载 并 使 用 外 部 函数 。 因 为 要 使 用 GD 库 函 数 ， 所 以 第 1 步 修改 
php.ini 文件 , 去 掉 “;extension=php_gd.dll” 这 一 行 行 首 的 “;”。 另外, 在 这 个 例子 中 要 用 到 wingdings.ttf 
字体 ， 所 以 要 把 wingdings.ttf 这 个 字体 文件 复制 到 PHP 文件 的 同一 个 目录 下 。 该 实例 要 实现 的 功能 是 
创建 一 个 图 像 文件 ， 并 在 图 像 上 画 出 一 些 图 形 。 具 体 代码 如 下 : 


<? 
Header("Content-type: image/png"); /| 输出 一 个 PNG 图 片 文件 
$im=imagecreate(440,100); 1/ 初始 化 图 形 区 域 
$black=imagecolorallocate($im, 0,0,0); /定义 黑色 
$white= imagecolorallocate($im, 255,255,255); /定义 和 白色 
$yellow= imagecolorallocate($im,255,255,0); /定义 黄色 
$blue = imagecolorallocate($im,0,0,255); /定义 蓝 色 
S$red= imagecolorallocate ($im,255,0,0); /定义 红色 
$zi= imagecolorallocate($im,255,0,255); /定义 紫色 
$color-$blue; /定义 $color 变量 为 蓝 色 
$font="wingdings.ttf"; /定义 字体 文件 
imagefilledrectangle($im, 5, 5, 435, 95, $color); // 用 蓝 色 画 一 个 矩形 
imagestring($im,5,7,10,"l:send",$white); /用 白色 写字 符 
for($i=0;$i<5;$i++) // 用 循环 画 字符 

{ 

imagettftext($im,40,0,90+$i*50,57 ,$yellow,$font,"Z"); 。”// 画 出 字符 用 黄色 及 字体 

} 
imagestring($im,5,270,60,"to:YOU As a gift", $white); /用 白色 写字 符 
imagestring($im,5,305,80,date(Y).".".date(m).".".date(d),$white); 。 // 写 出 当前 日 期 
imagepng($im); // 创 建 图 形 
imagedestroy($im); /关闭 图 形 
?> 


图 6.7 GD 库 函 数 使 用 实例 执行 结果 


因为 这 一 节 只 讲 怎 么 使 用 外 部 函数 ， 所 以 并 不 详细 说 明 函 数 具 体 是 怎么 使 用 的 。 关 于 GD 库 函 数 
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的 使 用 ， 将 会 在 第 10 章 PHP 中 的 图 像 处 理 中 专门 为 读者 介绍 。 
66 自 定义 函数 


在 实际 进行 PHP 编程 时 ， 由 于 要 面 对 的 情况 可 能 十 分 复杂 ， 仅 仅 依靠 PHP 内 置 的 库 函 数 ， 有 时 往 
往 不 能 实现 用 户 所 要 达到 的 目的 。 这 时 就 要 用 户 自 己 构造 函数 来 解决 实际 问题 。PHP 允许 用 户 使 用 自 
定义 函数 。 那 么 ， 自 定义 函数 应 该 怎么 用 呢 ? 这 一 节 就 来 解决 如 何 使 用 自 定义 函数 及 函数 的 动态 调用 、 
函数 的 递归 等 问题 。 


6.6.1 如 何 自 定义 函数 


在 PHP 中 , 自 定义 函数 是 一 件 很 简单 的 事情 。 只 需 使 用 以 下 语法 格式 就 可 以 完成 对 函数 的 自 定义 : 


function functionname() 


{ 
statement; 
return $retval; 


} 


从 以 上 代码 中 可 见 ， 要 自 定义 函数 ， 就 是 使 用 function 语句 ， 后 面 跟 函 数 名 加 “0”。 如 果 函 数 需 
要 参数 ， 就 要 把 参数 加 在 括号 内 。 函 数 体 部 分 用 “{}” 来 包括 起 来 ， 以 使 之 和 其 他 语句 分 开 。 大 括号 
内 是 函数 体 ， 其 中 包括 所 要 执行 的 内 容 、 返 回 值 等 。 

下 面 通过 一 个 实例 来 说 明 ， 如 何 完成 自 定义 函数 的 自 定义 。 


<html> 
<head> 
<title> 函 数 的 自 定义 实例 </title> 


function my_f($num1,$num2) // 定 义 函 数 求 两 个 数 的 最 小 公 们 数 


if($num1>$num2) // 如 果 前 面 数 大 两 者 互 换 
{ 

$temp=$num1; 

$num1=$num2; 

$num2=$temp; 
} 
$s=$num2; // 定 义 变量 备用 
$i=1; /定义 变量 备用 
while($s%$num1!=0) // 是 否 满足 最 小 公信 数 
{ 

$s=$num2*$i; // 大 数 翻 倍 


$i++; 
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} 
return $s; // 返 回 结果 
F 
echo my_f(1,3); // 输 出 1 与 3 的 最 小 公 售 数 
echo "<p>"; 
echo my_f(6,8); // 输 出 6 与 8 的 最 小 公 售 数 
echo "<p>"; 
echo my_f(13,29); /| 输出 13 5 29 的 最 小 公信 数 
echo "<p>"; 
echo my f(5,100); /| 输出 5 与 100 的 最 小 公信 数 
echo "<p>"; 
echo my_f(35,3); // 输 出 35 与 3 的 最 小 公 倍数 
echo "<p>' 
?> 
</body> DARMATLEM - Wi erosoft Tate KS EA 
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上 例 中 ， 定 义 了 一 个 函数 ， 作 用 是 通过 大 数 翻 倍 法 来 求 
两 个 数 的 最 小 公 倍数 。 保 存 以 上 代码 为 “6-8.php”。 在 PHP 3 


执行 环境 中 运行 以 上 代码 ， 执 行 结果 如 图 6.8 所 示 。 lo 
通过 上 例 ,读者 能 够 理解 到 PHP 中 是 如 何 自 定义 函数 的 。 105 
只 要 掌握 了 方法 ， 自 定义 函数 其 实 是 一 件 很 简单 的 事情 。 4 


COO O e 


6.6.2 ”使 用 自 定 义 函 数 图 6.8 函数 的 自 定义 实例 执行 结果 


自 定义 函数 在 完成 定义 后 ， 就 可 以 使 用 了 。 使 用 的 方法 也 相当 简单 ， 就 像 使 用 PHP 库 函 数 一 样 。 
代码 如 下 : 


function functionname(); 


函数 名 后 面 加 上 括号 ， 里 面 带 上 适当 的 参数 就 行 了 。 下 面 继 续 通 过 一 个 实例 来 说 明 ， 在 PHP 中 是 
如 何 使 用 自 定义 函数 的 。 


<html> 
<head> 


<title> 自 定义 函数 的 使 用 实例 </title> 


function my_f($num1,$num2,$num3) /定义 函数 求 一 元 二 次 方程 的 根 
{ 

if(($num2*$num2-4*$num1*$num3)<0) // 无 实 根 的 情况 

echo "方程 没有 实 根 !"; 

elseif(($num2*$num2-4*$num1*$num3)==0) /一 个 实 根 


echo "方程 有 一 个 实 根 : <p>"; 
echo (-$num2+sqrt($num2*$num2-4*$num1*$num3))/(2*$num1); 
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} 
else // 两 个 实 根 
{ 
echo "方程 有 两 个 实 根 : <p>"; 
echo (-$num2+sqrt($num2*$num2-4*$num1*$num3))/(2*$num1); 
echo", "; 
echo (-: -$num2-sqrt(Snum2*$num2-4"$num1*$num3))/(2"$num1 va 
} 
} 
echo "方程 : 2x<sup>2</sup>+3x+1=0 的 根 为 : <p>"; 
my f(2,3,1); // 调 用 函数 
echo "<p>"; 
echo "方程 : x<sup>2</sup>+9x+1=0 的 根 为 : <p>"; 
my_f(1,-6,9); // 调 用 函数 
echo "<p>"; 
echo "方程 ，3x<sup>2</sup>+2x+1=0 的 根 为 :，<p>"; 
my f(3,2,1); // 调 用 函数 
好 习 自 定 叉 商 数 的 使 用 实例 - Microsft atend aE] 
</body> ETTEN EN Ian 更 | a 
</html> 方程 ，2xz+3xtl=0 的 根 为 ， 
以 上 代码 定义 了 一 个 函数 , 该 函数 的 作用 是 使 用 公式 ti 
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法 求 一 元 二 次 方程 的 根 定义 完成 后 , 根据 3 种 不 同情 况 
调用 函数 。 把 以 上 代码 保存 为 “6-9.php”。 在 PHP 执行 


方程 ，x2-6x+9=0 的 根 为 ， 


环境 中 运行 以 上 代码 ， 执 行 结果 如 图 6.9 所 示 。 Goi 
这 一 节 ， 自 定义 函数 的 使 用 就 介绍 到 这 里 。 通 过 WE 
6-8.php 和 6-9.php 两 个 例子 ， 对 于 如 何 定义 一 个 函数 , 如 方程 没有 实 根 | 
何 使 用 自 定义 函数 ， 读 者 应 该 有 一 个 清晰 的 认识 了 。 Ne 


图 6.9 自 定义 函数 的 使 用 实例 执行 结果 
6.6.3 ”函数 的 动态 调用 


由 于 PHP 支持 可 变化 的 函数 概念 。 所 以 如 果 在 一 个 变量 的 名 称 后 面 加 上 一 对 圆 括号 “0”， 那 么 
PHP 将 去 寻找 与 这 个 变量 名 字 相同 的 函数 。 无 论 这 个 变量 的 数值 是 什么 ， 函 数 都 会 被 执行 。 这 个 过 程 
就 实现 了 函数 的 动态 调用 。 

为 了 形象 说 明 函 数 的 动态 调用 这 个 问题 ， 下 面 通过 实例 来 介绍 。 

<html> 

<head> 


<title> 函 数 的 动态 调用 实例 </title> 


</head> 


function my_f_1($text) /定义 函数 1 


echo "<font size=12pt>"; /以 12 号 字体 输出 文字 
echo $text; 
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echo "</font>"; 

} 

function my_f_2($text) // 定 义 函 数 2 

{ 
echo "<font size=20pt>"; /以 20 号 字体 输出 文字 
echo "<u>"; // 给 文字 加 上 下 划 线 效果 
echo $text; 
echo "</u>"; 
echo "</font>"; 

} 


$test="my_f_1"; 

S$test("| LIKE PHP!"); 

echo "<p>"; 

$test="my_f_2"; 

$test(" 用 PHP 编程 ， 其 实 很 简单 !"); 
> 

</body> 

</html> 


把 以 上 代码 保存 为 “6-10.php”。 在 PHP 执行 环境 中 
运行 以 上 代码 ， 将 出 现 如 图 6.10 所 示 的 执行 结果 。 

以 上 代码 先 定义 了 两 个 函数 ， 然 后 把 函数 名 称 赋值 为 
变量 。 变 量 名 后 加 上 括号 ，PHP 就 会 去 寻找 同名 的 函数 
my_f_1， 找 到 后 则 运行 ， 从 而 实现 了 函数 的 动态 调用 。 调 
用 my_f 2 的 过 程 与 之 类 似 。 

通过 上 面 的 实例 ， 相 信 读 者 对 PHP 中 如 何 动态 调用 函 a= 
数 已 经 有 了 一 定 程度 的 了 解 。 图 6.10 函数 的 动态 调用 实例 执行 结果 


1/ 动态 调用 my_f_1() 


1/ 动态 调用 my_f_2() 
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I LIKE PHP! 


用 PHP 编 程 ， 志 
实 很 简单 ! 
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6.6.4 RZA% 


这 一 小 节 来 介绍 PHP 函数 的 递归 。 那 么 什么 是 递归 呢 ? 其 实 递归 就 像 读 者 都 听 过 的 一 个 歌谣 那样 ; 
从 前 有 座 山 ， 山 里 有 座 庙 ， 庙 里 有 个 老 和 尚 和 一 个 小 和 尚 。 老 和 尚 给 小 和 尚 讲 故事 ， 故 事 里 说 从 前 有 
座 山 ， 山 里 有 座 庙 …… 就 像 这 样 无 限 循环 。 回 过 头 来 继续 说 递归 ， 递归 简 单 的 说 就 是 函数 自身 调用 自身 。 

有 时 通过 函数 的 递归 来 处 理 问 题 是 十 分 有 效 的 。 如 求 斐 波 纳 契 数列 第 N 项 的 值 ， 如 果 采 用 传统 方 
法 效率 很 低 。 但 如 果 使 用 函数 的 递归 ， 解 决 起 来 就 会 容易 的 多 。 下 面 就 通过 例子 来 说 明 函 数 的 递归 问题 。 

在 列 出 具体 代码 前 ， 先 来 了 解 一 下 斐 波 纳 契 数列 的 特点 。 斐 波 纳 契 数列 即 “ 免 子 生 兔子 的 问题 ”: 
有 一 个 人 把 一 对 兔子 放 在 四 面 封闭 的 地 方 。 假 定 每 个 月 一 对 兔子 生 下 另外 一 对 。 而 这 新 的 一 对 在 二 个 
月 后 就 生 下 另外 一 对 。 这 样 一 年 后 他 会 有 多 少 对 兔子 ? 这 里 对 这 个 数列 作 一 改动 ， 设 第 一 项 与 第 二 项 


为 1。 结 果 就 是 像 这 样 的 一 组 数列 : 1，1，2，3，5，8，13，21，34，55，89，144……- 即 某 一 项 为 它 
前 面 两 项 之 和 。 在 了 解 了 数列 的 特点 后 ， 下 面 就 通过 实际 使 用 函数 的 递归 ， 来 解决 这 一 问题 。 

<html> 

<head> 


<title> 函 数 的 递归 实例 </tile> 
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</head> 

<body> 

<? 

function Fibanacci($num) /定义 Fibanacci 函数 
if($num==1 || $num==2) // 如 果 为 第 一 项 和 第 二 项 
return 1; 1/ 返回 值 为 1 
else // 除 1、2 外 的 其 他 项 


return Fibanacci($num-1)+Fibanacci($num-2); // 递 归 调 用 前 两 项 之 和 


} 


3 

echo " 斐 波 纳 契 数列 的 第 1 项 为 :"; 
echo Fibanacci(1); 

echo "<p>"; 

echo " 斐 波 纳 契 数列 的 第 12 项 为 :"; 
echo Fibanacci(12); 

echo "<p>"; 

echo " 斐 波 纳 契 数列 的 第 7 项 为 :"; 
echo Fibanacci(7); 

echo "<p>"; 

echo " 斐 波 纳 契 数列 的 第 20 项 为 :"; 
echo Fibanacci(20); 

?> 

</body> 

</html> 


保存 以 上 代码 为 “6-11.php”。 在 PHP 执行 环境 中 运行 
以 上 代码 ， 执 行 结果 如 图 6.11 所 示 。 

以 上 代码 中 当 参 数 为 1 或 2 的 情况 很 容易 理解 , 直接 返 
回 1 即 可 。 除 此 以 外 的 情况 直接 返回 了 和 数组 定义 完全 相同 
的 公式 : 某 一 项 为 其 前 两 项 之 和 ， 从 而 实现 了 函数 的 递归 。 

可 以 看 出 使 用 函数 的 递归 解决 此 类 问题 相对 于 用 迭代 
法 来 说 是 简单 的 、 有 效 的 。 

另外 ， 在 使 用 函数 递归 时 要 注意 以 下 两 个 问题 : 
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图 6.11 函数 的 递归 实例 执行 结果 


口 在 递归 中 要 有 使 递归 中 止 的 代码 ， 不 能 使 递归 陷入 无 限 循环 之 中 。 
口 同时 要 避免 递归 函数 调用 超过 100~200 层 的 范围 , 因为 可 能 会 破坏 堆栈 从 而 使 当前 脚本 终止。 


6.7 本 章 小 结 


这 一 章 介 绍 了 PHP 中 函数 的 使 用 方法 。 其 中 讲 了 什么 是 函数 、 函 数 的 参数 和 返回 值 、PHP 库 函数 
的 使 用 、 外 部 函数 的 加 载 及 自 定义 函数 。 正 如 本 章 开始 时 提 到 的 ， 函 数 是 PHP 的 最 重要 的 组 成 部 分 ， 
只 有 熟练 的 使 用 函数 ， 才 算是 真正 学 会 了 PHP。 通 过 本 章 的 学 习 使 读者 对 PHP 中 函数 的 使 用 有 了 一 定 了 
解 。 关 于 具体 的 函数 如 何 使 用 ， 从 第 7 章 开 始 将 用 9 章 的 篇 幅 专门 为 读者 讲解 PHP 中 各 种 库 函 数 的 使 用 。 


怎样 判断 数据 类 型 

PHP 让 帘 用 的 数学 函数 
PHP 中常 用 的 字符 率 函 数 
PHP 让 帘 用 的 数组 函数 


aa aa 


数据 处 理 在 PHP 编程 中 有 重要 的 地 位 ， 不 论 是 编 什 么 样 的 程序 都 少不了 和 各 种 各 
样 的 数据 打交道 。 本 章 为 读者 介绍 PHP 中 对 数据 的 处 理 即 PHP 中 有 关 数 据 处 理 的 库 函 
数 。 内 容 包括 判断 数据 类 型 、 常 用 数学 函数 、 字 符 串 函数 、 数 组 函数 等 。 数 据 处 理 是 编 
写 大 型 Web 应 用 程序 的 基础 ， 只 有 正确 地 对 数据 进行 相应 的 处 理 才 能 为 大 型 应 用 程序 
提供 数据 基础 支持 。 
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怎样 判断 数据 类 型 


在 使 用 数据 变量 时 ， 先 弄 清 该 变量 属于 什么 类 型 是 很 有 必要 的 。 只 有 知道 了 数据 变量 的 类 型 ， 才 
能 对 它 进行 相关 的 操作 。 那 么 PHP 中 是 如 何 判 断 数据 类 型 的 呢 ? 
在 PHP 中 有 专门 的 函数 来 判断 数据 的 类 型 ， 这 就 是 Is 系列 函数 。 常 用 的 判断 数据 类 型 函数 见 


表 7.1。 


函 数 名 


is_array(mixed var) 
is_bool(mixed var) 
is_float(mixed var) 


is_int(mixed var) 


is_null(mixed var) 


is_numeric(mixed var) 


is_object(mixed var) 


is_scalar(mixed var) 


表 7.1 
作 用 


判断 变量 是 否 为 数组 
判断 变量 是 否 为 布尔 型 
判断 变量 是 否 为 浮 点 数 


判断 变量 是 否 为 整 型 变量 


判断 变量 是 否 为 NULL 值 


判断 变量 是 否 为 数字 或 者 数字 字符 串 


判断 变量 是 否 为 一 个 对 象 


判断 变量 是 否 为 一 个 标量 〈 标 量 即 最 小 的 变 
量 单位 , 只 包括 integer、 float, string 或 boolean 
的 变量 ， 而 array (HHA) ~ object (对 象 ) 和 
resource (HW) 则 不 是 标量 ) 
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返 回 值 
如 果 参 数 var 是 数组 就 返回 Trme， 否 则 返回 
False 
如 果 参 数 var 是 布尔 型 值 即 True 或 False 就 返 
加 True， 否则 返回 False 
果 参 数 var 是 浮 点 数 则 返回 True， 否 则 返 
False 
如 果 参 数 var 为 整 型 变量 INT 则 返回 True， 否 
则 返回 False 
如 果 参 数 var 未 被 定义 或 者 被 设置 为 NULL 或 
者 虽然 已 经 被 定义 但 又 被 unset() 取 消 定义 ， 
则 返回 Trme， 否 则 返回 False 
如 果 参 数 var 为 数字 或 者 数字 字符 串 则 返回 
True， 否 则 返回 False 
如 果 参 数 var 为 OBJECE 就 返回 True， 和 否则 返 


slFalse 


回 


如 果 参 数 var 为 标量 则 返回 True， 和 否则 返回 


False 


is_string(mixed var) 


isset(mixed var) 


判断 变量 是 否 为 字符 串 


判断 变量 是 否 设置 


如 果 参 数 var 为 字符 串 返回 True， 否 则 返 
False 

如 果 变 量 存在 就 返回 True， 否 则 返回 False。 
另外 被 设置 为 NULL 值 的 变量 在 使 用 isset() 时 
也 将 返回 False 

该 函数 只 能 用 于 变量 ， 因 为 传递 任何 其 它 参 
数 都 将 造成 解析 错误 


回 


表 7.1 列 出 了 PHP 中 判断 数据 类 型 的 函数 。 在 了 解 了 这 些 函 数 后 ， 下 面 通过 实例 来 说 明 这 些 函 数 
是 如 何 应 用 的 。 请 参看 以 下 代码 : 
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<html> 
<head> 
<title>PHP 判断 数据 类 型 使 用 实例 </title> 


</head> 


// 先 设置 一 些 变量 备用 
$num1=123; 
$arr=array(1,2,3,4,5,6,7); 
$bool1=FALSE; 
$b=Null; 
$num2=3.14159; 
S$string1="123456"; 
$string2="HELLO WORLD!" 
class foo NENH R 
{ 

function do_foo() 

{ 

echo "Doing foo."; 
} 


F 

$bar = new foo; /引用 对 象 

iflis aray($arr)) /是 否 为 数组 
echo $arr." 是 数组 "; 

echo "<br>"; 

if(lis array($num1)) /是 否 为 数组 
echo $num1." 不 是 数组 ! "; 

echo "<br>"; 

if(lis_bool($num1)) /是 否 为 布尔 型 
echo $num1." 不 是 布尔 型 !"; 

echo "<br>"; 

ifis_bool($bool1) /是 否 为 布尔 型 
echo $bool1." 是 布尔 型 "; 

echo "<br>"; 

if(lis foat($num1)) /是 否 为 浮 点 型 
echo $num1." 不 是 浮 点 型 !"; 

echo "<br>"; 

if(is_float($num2)) /是 否 为 浮 点 型 
echo $num2." 是 浮 点 型 "; 

echo "<br>"; 

if(is_int($num1)) /是 否 为 整 型 
echo $num1." 是 整 型 "; 

echo "<br>"; 

if(lis_int($num2)) /是 否 为 整 型 
echo $num2." 不 是 整 型 ! "; 

echo "<br>"; 

iflis numeric($string1)) /是 否 为 数字 或 数字 字符 串 
echo $string1." 是 数字 "; 

echo "<br>"; 

if(!lis_numeric($string2)); /是 否 为 数字 或 数字 字符 串 
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echo $string2." 不 是 数字 !"; 


echo "<br>"; 
if(is_object($bar)) // 是 否 为 对 象 
print r($bar);echo "是 OBJCET"; 
echo "<br>"; 
if(lis_object($num1)) /是 否 为 对 象 
echo $num1." 不 是 OBJECT! "; 
echo "<br>"; 
if(is_scalar($num1)) /是 否 为 标量 
echo $num1." 是 标量 "; 
echo "<br>"; 
if(lis scalar($arr)) /是 否 为 标量 
echo $arr." 不 是 标量 ! "; 
echo "<br>"; 
if(!is_string($num1)) // 是 否 为 字符 串 
echo $num1." 不 是 字符 串 ! "; 
echo "<br>"; 
if(is_string($string1)) /是 否 为 字符 串 TEE 
echo $string1." 是 字符 串 "; [ERD ARD EEO IRD za =| 居 
echo "<br>"; p E 
iflisset($string1)) /是 否 有 值 TEENE 
echo $string1." 有 值 "; Ema S 
echo "<br>"; a 
if(!isset($b)) // 是 否 有 值 DARE 
echo $bool1." 无 值 或 者 值 为 Null! "; piapa 
echo "<br>";?> EEB ui 
</body> IRE 
S voen 
123456 是 字符 种 

保存 以 上 代码 为 “7-1.php”。 在 PHP 运行 环境 中 执 E 

行 以 上 代码 ， 执 行 结 果 如 图 7.1 所 示 。 A 
通过 该 例子 ， 可 以 了 解 到 在 PHP 中 使 用 相关 函数 ， [Te 

来 判断 数据 类 型 是 一 件 很 简单 的 事情 。 图 7.1 PHP 判断 数据 类 型 使 用 实例 执行 结果 


7.2 PHP 中 常用 的 数学 函数 


数学 运算 、 数 字 的 操作 在 PHP 的 数据 处 理 中 占有 很 大 比重 。 无 论 是 大 型 的 程序 ， 还 是 只 有 儿 行 代 
码 的 小 程序 ， 只 要 牵涉 到 数字 都 需要 用 数学 的 方法 进行 处 理 。 这 一 节 就 来 向 读者 介绍 PHP 中 常用 的 数 


7.2.1 数学 计算 函数 


这 一 小 节 为 读者 介绍 常用 的 数学 计算 函数 ， 详 见 表 7.2。 


函 数 名 


abs(mixed var) 
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表 7.2 PHP 中 常用 的 数学 计算 函数 


作 


绝对 值 函数 ， 返 回 参数 var 的 绝对 值 


.75° 


返 回 值 


如 果 参 数 为 正 ， 直 接 返 
返回 


[E] 


如 果 为 负 ， 去 掉 负 号 后 


ceil(float value) 


进 一 法 取 整 数 函数 ， 返 回 不 小 于 参数 value 


的 下 一 个 整数 


如 果 参 数 为 整 型 数 ， 直 接 返 


HS: 如 果 参 数 为 浮 点 


型 数 ， 则 返回 值 为 参数 的 小 


数 部 分 进 一 位 


exp(float arg) 


计算 指数 函数 ， 计 算 e 的 指数 。 


用 e 作 为 自然 对 数 的 底 2.718282 返 回 e 的 arg 次 方 值 


floor(float,value) 


合 去 法 取 整 数 函 数 ， 返 回 不 大 于 参数 value 


如 果 参 数 为 整 型 数 ， 直 接 返 


可 参数 ;如果 参数 为 浮 点 


的 下 一 个 整数 型 数 ， 则 返回 值 为 参数 合 去 小 数 部 分 后 的 值 
log100 计算 对 数 函 数 。 返 回 以 10 为 底 的 对 数 返回 以 10 为 底 的 对 数值 
sqrt(float 计算 平方 根 函 数 。 返 回 参数 arg 的 平方 根 返回 参数 arg 的 平方 根 


在 了 解 了 这 类 数学 计算 函数 后 ， 下 面 通过 具体 的 实例 来 向 读者 介绍 如 何 使 用 。 代 码 如 下 : 


<html> 
<head> 


<title>PHP 数学 计算 函数 使 用 实例 </title> 


echo "3 的 绝对 值 是 : “; 


echo abs(-3); 


echo "<P>"; 


echo "3 的 绝对 值 是 :"; 


echo abs(3); 


echo "<P>"; 


echo "不 小 于 5.5 的 最 小 整数 是 :"; 


echo ceil(5.5); 


echo "<P>"; 


echo "不 小 于 -8.2 的 最 小 整数 是 :"; 
echo ceil(-8.2); 


echo "<P>"; 


echo "e 的 3 次 方 是 :"; 


echo exp(3); 


echo "<P>"; 


echo "不 大 于 3.2 的 最 大 整数 是 : "; 
echo floor(3.2); 


echo "<P>"; 


echo "不 大 于 -8.8 的 最 大 整数 是 :"; 
echo floor(-8.8); 


echo "<P>"; 


echo "100 以 10 为 底 的 对 数 为 :"; 
echo log10(100); 


echo "<P>"; 


echo "9 的 平方 根 是 :"; 


echo sqrt(9); 


// 输 出 -3 的 绝对 值 


// 输 出 3 的 绝对 值 


// 输 出 不 小 5.5 的 最 小 整数 


/输出 不 小 于 -8.2 的 最 小 整数 


/输出 e 的 3 次 方 


/输出 不 大 于 3.2 的 最 大 整数 


// 输 出 不 大 于 -8.8 的 最 大 整数 


/| 输出 100 以 10 为 底 的 对 数 


/输出 9 的 平方 根 
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echo "<P>"; 
?> 

</body> 
</html> 


保存 以 上 代码 为 “7-2.php”。 在 PHP 执行 环境 中 运 
行 以 上 代码 ， 运 行 结果 如 图 7.2 所 示 。 

通过 上 述 例子 及 执行 结果 能 够 发 现 , 通过 PHP 中 的 
数学 计算 函数 能 对 数据 进行 各 种 数学 计算 。 熟 练 掌握 这 
些 函数 将 对 以 后 的 数据 处 理 十 分 有 益 。 


ei Mi eraras 


Bi 
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-3 的 绝对 值 是 ，3 

3 的 绝对 值 是 :3 

不 小 于 5. 5 的 最 小 整数 是 ，6 
不 小 于 -8. 2 的 最 小 整数 是 ，8.2 
e 的 3 次 方 是 ，20. 085536923188 
不 大 于 3. 2 的 最 大 整数 是 ，3 
不 大 于 -8. 8 的 最 大 整数 是 ，-9 
100 以 10 为 底 的 对 数 为 ，2 


9 的 平方 根 是 ， 3 


722 数学 三 角 函 数 


zi 
CE a a Er F) 


图 7.2 PHP 数学 计算 函数 使 用 实例 执行 结果 


这 一 小 节 来 介绍 常用 的 数学 三 角 函 数 。 在 介绍 三 角 
函数 之 前 先 介 绍 一 个 函数 : deg2rad() 函 数 ， 它 的 作用 是 
把 角度 转换 为 弧度 。 

学 过 三 角 函 数 的 读者 都 知道 ， 三 角 函 数 就 是 指正 弦 、 余 弦 、 正 切 、 余 切 以 及 这 些 函 数 对 应 的 反 函 
数 等 。PHP 中 也 有 类 似 的 函数 ， 并 且 表 达 方 法 几乎 与 数学 的 表达 方法 一 样 。PHP 中 的 常用 三 角 函 数 有 
以 下 几 个 ， 见 表 7.3。 


表 7.3 PHP 中 常用 的 三 角 函 数 


函数 名 | 作 用 | 返 回 值 

sin(float arg) 返回 参数 arg 的 正弦 值 ， 参 数 arg 为 弧度 

cos(float arg) 返回 参数 arg 的 余弦 值 ， 参 数 arg 为 弧度 

tan(float arg 返回 参数 arg 的 正切 值 ， 参 数 arg 为 弧度 

asin(float arg 返回 参数 arg 的 反正 弦 值 ， 参 数 arg 为 弧度 。 范 数 asin() 是 函数 sin0 的 反 函 数 
acos(float arg 返回 参数 arg 的 反 余弦 值 ， 参 数 arg 为 弧度 。 函 数 acos() 是 函数 cos() 的 反 函 数 
atan(float arg) 返回 参数 arg 的 反正 切 值 ， 参 数 arg 为 弧度 。 函 数 atan() 是 函数 tan() 的 反 函 数 


下 面 通过 两 个 实例 来 说 明 在 PHP 中 如 何 使 用 这 些 三 角 函 数 。 
首先 来 看 看 简单 三 角 函 数 的 使 用 。 代 码 如 下 : 
<html> 


<head> 
<title>PHP 三 角 函 数 使 用 实例 1</title> 


echo "30 度 角 的 正弦 值 为 :"; 
echo sin(pi()/6); 

echo "<p>"; 

echo "270 度 角 的 正弦 值 为 : "; 
echo sin(pi()/2*3); 


/计算 正弦 


第 7 章 PHP 的 数据 处 理 ua 


echo "<p>"; 

echo "60 度 角 的 余弦 值 为 : “; 

echo cos(pi()/3); HARÉ 

echo "<p>"; 

echo "0 度 角 的 余弦 值 为 :"; 

echo cos(0); 

echo "<p>"; 

echo "45 度 角 的 正切 值 为 :"; 

echo tan(pi()/4); // 计 算 正 切 

echo "<p>"; 

echo "90 度 角 的 正切 值 为 :"; 

echo tan(pi()/2); 

echo "<p>"; 

echo "30 度 角 的 反正 弦 值 为 : 委 PT 二 入 西江 使 用 实例 ! - winrasiEI katani 

echo asin(pi()/6); /1 计算 反 正弦 ET esv aw AU II 

echo ka AGOA SEA 0.5 B 

echo "60 A 为 :"; Wo 

echo acos(pi()/3); // 计 算 反 余弦 i 

echo "<p>"; SAIZI 0.5 

echo "45 度 角 的 反正 切 值 为 : "; /计算 反正 切 ANGE 

echo atan(pi()/4); 45 度 角 的 正切 值 为 ，1 

echo "<p>";?> 30 度 角 的 正切 值 为 ，1. 65331778728384E+016 

</body> 30 度 角 的 反正 弦 依 为 ，0. 55106958309945 

</html> 60 度 角 的 反 作 续 信 为 ，-1. HD 

保存 以 上 代码 为 “7-3.php”。 在 PHP 执行 环境 中 运行 以 ka 

上 代码 ， 执 行 结 果 如 图 7.3 所 示 。 mi 了 
接 下 来 , 使 用 三 角 函数 结合 GD 函数 来 实现 画图 功能 (更 EEC 
多 关于 GD 库 函 数 的 使 用 方法 请 参看 本 书 第 10 章 ) 。 图 7.3 PHP 三 角 函 数 使 用 实例 1 执行 结果 

<? 

Header("Content-type: image/png"); // 输 出 文件 头 为 PNG 图 片 

$im = imagecreate(400,400); /使 用 GD 库 函 数 创建 区 域 

S$black = Imagecolorallocate($im, 0,0,0); IERA GD 库 函 数 定义 黑色 

$white = Imagecolorallocate($im, 255,255,255); /使 用 GD 库 函 数 定义 白色 

$yellow = Imagecolorallocate($im,255,255,0); MBA GD 库 函 数 定义 黄色 

$blue = Imagecolorallocate($im,0,0,255); // 使 用 GD 库 函 数 定义 蓝 色 

$red = Imagecolorallocate($im,255,0,0); MBA GD 库 函 数 定义 红色 

imagefilledrectangle($im, 5, 5, 395, 395, $yellow); /使 用 GD 库 函 数 画 和 矩形 

for($i=1;$i<360;$i++) // 通 过 循环 画 点 

{ 
$temp=150*sin(2*(pi()/180)*$i); // 通 过 三 角 函 数 计算 值 
$x=$temp*cos((pi()/180)*$i)+200; // 通 过 三 角 函 数 计算 点 的 横 坐 标 
$y=$temp*sin((pi()/180)*$i)+200; // 通 过 三 角 函 数 计算 点 的 纵 坐 标 
imagesetpixel ($im,$x,$y,$red); /通过 GD FAREA 
S$temp=150*cos(2*(pi()/180)*$i); // 通 过 三 角 函 数 计算 第 2 个 值 
$x=$temp*cos((pi()/180)*$i)+200; /通过 三 角 函 数 计算 点 的 横 坐标 
$y=$temp*sin((pi()/180)*$i)+200; /通过 三 角 函 数 计算 点 的 纵 坐 标 


imagesetpixel ($im,$x,$y,$blue); // 通 过 GD FAREA 


} 

ImagePNG($im); /输出 PNG 图 片 
ImageDestroy($im); /清空 图 片 

?> 


在 运行 这 个 代码 以 前 , 要 加 载 GD 库 函 数 到 PHP AERE Gro san a0 WR TAD Rm Te 


器 中 。 保存 以 上 代码 为 “7-4.php”。 然 后 在 PHP 执行 环境 
中 运行 以 上 代码 ， 执 行 结果 如 图 7.4 所 示 。 

代码 运行 之 后 ， 在 屏障 上 画 出 漂亮 的 花 的 图 案 。 这 一 
方面 说 明了 PHP 功能 的 强大 ， 同 时 也 是 PHP 三 角 函 数 使 
用 带 来 的 奇妙 效果 。 不 过 请 不 要 过 分 关注 其 中 GD 库 函 数 
的 使 用 方法 ， 关 于 其 中 的 GD 库 函 数 ， 将 在 第 10 章 PHP 
中 的 图 像 处 理 中 详细 为 读者 做 介绍 。 

PHP 的 三 角 函 数 使 用 ， 这 一 节 就 介绍 到 这 里 。 


7.2.3 很 有 用 的 最 值 函 数 


zi 
ISE COT T Oue YA 


如 果 给 出 一 组 数据 让 求 最 大 《小 ) 值 ， 应 该 怎么 做 ? 图 74 PHP 三 角 函数 使 用 实例 2 执行 结 果 
在 通常 的 编程 语言 中 ， 要 先 把 一 组 数 赋值 给 一 个 数组 ， 然 
后 再 对 数组 进行 冒 泡 法 排序 。 最 后 再 把 得 出 的 结果 赋值 给 一 个 变量 。 真 是 相当 麻烦 。 在 PHP 中 这 一 切 
就 变 得 很 简单 了 ， 因 为 PHP 库 函 数 中 就 为 用 户 提供 了 求 一 组 数据 最 值 的 函数 。PHP 中 的 最 值 函数 有 以 
下 儿 种 : 
O Max(Number Argl, Number Arg2)， 求 最 大 值 函数 ， 返 回 参 数 中 数值 最 大 的 值 。 如 果 仅 有 一 个 
参数 且 为 数组 ，Max0) 返 回 该 数组 中 最 大 的 值 。 如 果 第 1 个 参数 是 整数 、 字 符 串 或 浮 点 数 ， 则 
至 少 需要 两 个 参数 而 Max() 会 返回 这 些 值 中 最 大 的 一 个 。 可 以 比较 无 限 多 个 值 。 
O Min(Number Argl, Number Arg2)， 求 最 小 值 函数 ， 返 回 参数 中 数值 最 小 的 值 。 如 果 仅 有 一 个 
参数 且 为 数组 ，Min() 返 回 该 数组 中 最 小 的 值 。 如 果 第 1 个 参数 是 整数 、 字 符 串 或 浮 点 数 ， 则 
至 少 需要 两 个 参数 而 Min0) 会 返回 这 些 值 中 最 小 的 一 个 。 可 以 比较 无 限 多 个 值 。 
下 面 通过 两 个 实例 来 介绍 在 实际 的 编程 中 如 何 使 用 这 两 个 函数 及 注意 事项 。 
1. Max0 函 数 使 用 实例 


<html> 

<head> 

<title>max() 函 数 使 用 实例 </title> 
</head> 


echo "1,3,5,6,7 中 数值 最 大 的 是 :"; 

echo max(1,3,5,6,7); /比较 多 个 数值 
echo "<p>"; 

echo "数组 array(2,4,5) 中 最 大 的 值 是 : "; 

echo max(array(2, 4, 5)); /比较 一 个 数组 
echo "<p>"; 
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echo "0 与 “hello” 中 最 大 的 是 : "; 
echo max(0, 'hello'); 

echo "<p>"; 

echo" “hello” 5 0 中 最 大 的 是 : "; 
echo max('hello', 0); 

echo "<p>"; 

echo "-1 与 “hello” 中 最 大 的 是 : "; 
echo max(-1, 'hello'); 

echo "<p>"; 

/对 多 个 数组 ，max 从 左 向 右 比 较 。 
// 因 此 在 本 例 中 : 2==2, 但 4<5 


/比较 数 及 字符 串 


echo "数组 array(2,4,8) 与 数组 array(2,5,7) 中 最 大 的 是 : "; 


$val=max(array(2,4,8), array(2,5,7)); 
for($i=0;$i<count($val);$i++) 


{ 
echo $val[$i]; 
echo", "; 

} 

echo "<p>"; 


/如 果 同 时 给 出 数组 和 非 数组 作为 参数 ， 则 总 是 将 数组 视 为 


/最 大 值 返回 


echo "数组 array(2,5,7) 与 “string” 和 42 中 最 大 的 是 : "; 


$val = max('string', array(2, 5, 7), 42); 
for($i=0;$i<count($val);$i++) 


echo $val[$i]; 
echo", "; 

} 

?> 

<body> 

</html> 


保存 以 上 代码 为 “7-5.php”。 在 PHP 执行 环境 


中 运行 以 上 代码 ， 执 行 结果 如 图 7.5 所 示 。 


从 以 上 实例 及 结果 中 可 以 看 到 Max0 函 数 在 不 


同 的 情况 下 是 如 何 运行 的 。 
2. Min0 函 数 使 用 实例 


<html> 
<head> 
<title>min() 函 数 使 用 实例 </title> 


</head> 


echo "1,3,5,6,7 中 数值 最 小 的 是 :"; 
echo min(1,3,5,6,7); 

echo "<p>"; 

echo "数组 array(2,4,5) 中 最 小 的 值 是 : "; 
echo min(array(2, 4, 5)); 
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1,3,5, 5, 7 中 数值 最 大 的 是 ，7 

数组 array(2, 4, 5) 中 最 大 的 值 是 ，5 

0 与 “hello ”中 景 大 的 是 ，0 

“hello ”与 0 中 最 大 的 是 ，hello 

-15 “hello “中 最 大 的 是 : hello 

数组 array(2, 4 8) 与 数组 array(2, 5, 7) 中 景 大 的 是 ，2，5，7， 


数组 array (2, 5 1) 与 “string ”和 42 中 景 大 的 是 ，2，5，?， 


ala 


asr COT T Oie 


图 7.5 max0 函 数 使 用 实例 执行 结果 


/比较 多 个 数值 


/比较 一 个 数组 
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echo "<p>"; 

echo "0 与 “hello” 中 最 小 的 是 : "; 

echo min(0, 'hello'); /比较 数 及 字符 串 
echo "<p>"; 

echo" “hello” 5 0 中 最 小 的 是 : "; 

echo min(hello', 0); 

echo "<p>"; 

echo "-1 与 “hello” 中 最 小 的 是 : "; 

echo min(-1, 'hello'); 

echo "<p>"; 

/对 多 个 数组 ，min 从 左 向 右 比较 。 

/因此 在 本 例 中 : 2==2, 但 4<5 

echo "数组 array(2,4,8) 与 数组 array(2,5,7) 中 最 小 的 是 : "; 
$val=min(array(2,4,8), array(2,5,7)); 
for($i=0;$i<count($val);$i++) 


{ 
echo $val[$ij]; 
echo", "; 

} 

echo "<p>"; 


// 如 果 同 时 给 出 数组 和 非 数 组 作为 参数 ， 则 不 可 能 返回 数组 
/因为 数组 被 看 作 是 最 大 的 。 最 大 值 返 回 

echo "数组 array(2,5,7) 与 “string” 和 42 中 最 小 的 是 :"; 
$val = min('string', array(2, 5, 7), 42); 


echo $val; 

?> 

<body> 
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保存 以 上 代码 为 “7-6.php”。 在 PHP 执行 环境 中 运 ADUNAREA E] 
行 以 上 代码 ， 就 会 看 到 如 图 7.6 所 示 的 执行 结果 。 的 
通过 以 上 实例 及 实例 执行 结果 ， 可 以 了 解 到 Min) | 65 arpea, o 
函数 的 运行 机 理 ， 及 在 不 同 的 情况 下 的 返回 值 情况 。 在 “hello ”与 0 中 景 小 的 是 ，hello 
使 用 这 两 个 函数 时 要 注意 以 下 问题 : 了 与 “hello“ 中 最 小 的 是 ， -1 
口 两 个 函数 都 是 从 左 向 右 比较 。 所 以 ， 如 果 相 同 | 数组 wray(2,4,8) 与 数组 array(2,5,7) 中 景 小 的 是 , 2，4，8， 
的 两 个 值 比较 优先 返回 左边 的 值 ( 见 上 面 两 个 数组 arzay (2, 5,7) 与 “strine ”和 42 中 景 小 的 是 ，string 


加 
例子 中 的 HELLO 字符 串 与 0 比较 的 情况 ) E= — 
O ”如 果 同 时 给 出 数组 和 非 数 组 作为 参数 ， 则 数组 图 7.6 min0 函 数 使 用 实例 执行 结果 


被 认为 是 最 大 的 。 所 以 Max0 函 数 必定 返回 数组 ;而 Min0) 函 数 必定 不 返回 数组 。 
这 一 小 节 中 PHP 的 最 值 函数 就 为 读者 介绍 到 这 里 。 


7.2.4 产生 随机 数 函 数 


在 进行 PHP 编程 的 时 候 ， 有 时 需要 一 些 随机 的 数字 。 比 如 用 户 身 份 验证 ， 为 了 防止 站 外 提交 ， 生 
成 一 组 随机 数字 ， 然 后 在 后 台 判 断 。 如 果 随 机 数 与 系统 要 求 的 不 一 样 就 不 允许 其 他 操作 。 那 么 应 该 如 
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何 生成 随机 数 呢 ? PHP 中 有 专门 的 随机 数 函数 。 
Rand([int min, int max]) 函 数 ， 产 生 一 个 随机 数 。 随 机 数 的 范围 在 参数 Min 与 Max 之 间 。 如 果 省 略 
参数 , 则 返回 0 到 RAND_MAX 之 间 的 伪 随 机 整数 。 下 面 通过 一 个 实例 说 明 RandO 函 数 是 如 何 使 用 的 。 


<html> 

<head> 

<title>rand() 随 机 函数 使 用 实例 </title> 

</head> 

<body> 

<? 

echo "生成 一 位 随机 数 :"; 

echo rand(1,9); /生成 一 位 随机 数 

echo "<p>"; 

echo "生成 无 参数 随机 数 : "; 

echo rand(); /| 无 参数 随机 数 1 

echo "<p>"; 

echo "生成 无 参数 随机 数 2; "; 

echo rand(); // 无 参数 随机 数 2 

echo "<p>"; 

echo "生成 四 位 随机 数 : "; 

echo rand(1000,9999); /| 生成 一 个 四 位 随机 数 

?> 

</body> 

</html> 

保存 以 上 代码 为 “7-7.php”。 在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 格式 如 图 7.7 所 示 〔 因 
生成 数 为 随机 数 ， 所 以 结果 数值 应 该 不 一 定 相同 ) 。 ETT err w mai ATII 

通过 实例 可 见 ， 在 PHP 中 生成 一 个 随机 数 是 一 件 很 简单 zro mo mv so me") z) 
的 事情 生成 一 们 随机 数 ，3 

za ' A a i a 生成 无 参 数 随 机 数 ，24583 

在 使 用 rand() 函 数 时 有 一 点 需要 注意 。 在 PHP 4.2 以 前 的 NE 
版 本 中 ， 要 想 使 用 rand() 函 数 必须 先 使 用 srand() 函 数 为 randi) KAB, 4675 
生成 种 子 ， 然 后 才能 使 用 rand0 函 数 。 不 过 新 版 本 的 PHP 已 经 am 
取消 了 这 种 设 定 。 可 以 直接 使 用 rand() 随 机 函数 。 图 77 rand0 随 机 函数 使 用 实例 执行 结果 


7.2.5 ” 进 制 转换 函数 


在 实际 工作 中 ， 有 时 需要 进行 进 制 的 转换 。 比 如 把 十 进 制 转换 为 二 进 制 ， 或 者 把 十 六 进 制 的 数 转 
换 为 十 进 制 等 。PHP 的 库 函 数 中 也 为 用 户 准备 好 了 这 样 的 函数 。PHP 中 的 进 制 转换 函数 一 共有 以 下 6 
种 ， 见 表 7.4。 


表 7.4 PHP 中 的 进 制 转 换 函 数 


函 数 名 作 用 
bindec(string binary string) | 二 进 制 转换 为 十 进 制 
十 进 制 转化 为 二 进 制 


返 回 值 
返回 参数 binary_string 二 进 制 数 对 应 的 十 进 制 等 价值 
返回 参数 int 十 进 制 数 对 应 的 二 进 制 等 价值 


decbin(int number) 


。82 。 PHP 网 络 编程 从 入 门 到 精通 


续 表 


dechex(int number) 十 进 制 转化 为 十 六 进 制 
decoct(int number) | 十 进 制 转 化 为 八进制 

hexdec(string hex_string) | 十 六 进 制 转化 为 十 进 制 
ctdec(string octal_string) 函 数 八进制 转换 为 十 进 制 


返回 参数 int 十 进 制 数 对 应 的 十 六 进 制 等 价值 
返回 参数 int 十 进 制 数 对 应 的 八进制 等 价值 

返回 参数 hex_string 十 六 进 制 数 对 应 的 十 进 制 等 价值 
返回 参数 octal_string 八 进 制 数 对 应 的 十 进 制 等 价值 


通过 以 上 介绍 可 以 发 现 ， 十 进 制 可 以 直接 和 二 进 制 、 八 进 制 、 十 六 进 制 进行 转换 。 同 时 二 进 制 、 
八进制 、 十 六 进 制 也 可 以 直接 转换 为 十 进 制 。 但 是 它们 之 间 的 转换 ， 就 只 有 通过 十 进 制 数 来 进行 了 。 
下 面 通过 一 个 实例 来 说 明 , 在 PHP 编程 中 是 如 何 使 用 这 些 进 制 转换 函数 的 。 具体 过 程 参 看 如 下 代码 : 


<html> 
<head> 
<title> 进 制 转换 函数 使 用 实例 </title> 


// 定 义 变量 备用 

$bin="11001"; 

$dec=100; 

$hex="12F"; 

$oct="77"; 

echo "二 进 制 数 ".$bin." 对 应 的 十 进 制 数 为 :"; 

echo bindec($bin); // 二 进 制 转换 为 十 进 制 
echo "<p>"; 

echo "十 进 制 数 ".$dec." 对 应 的 二 进 制 数 为 :"; 

echo decbin($dec); 1/ 十进制 转换 为 二 进 制 
echo "<p>"; 

echo "十 进 制 数 ".$dec." 对 应 的 八进制 数 为 :"; 

echo decoct($dec); 1/ 十 进 制 转换 为 八进制 
echo "<p>"; 

echo "十 进 制 数 ".$dec." 对 应 的 十 六 进 制 数 为 :"; 

echo dechex($dec); /| 十进制 转换 为 十 六 进 制 
echo "<p>"; 

echo "八进制 数 ".$oct." 对 应 的 十 进 制 数 为 :"; 

echo octdec($oct); /八进制 转换 为 十 进 制 
echo "<p>"; 

echo "十 六 进 制 数 ".$hex." 对 应 的 十 进 制 数 为 : "; 

echo hexdec($hex); /十 六 进 制 转换 为 十 进 制 
echo "<p>"; 

echo "二 进 制 数 ".$bin." 对 应 的 八进制 数 为 :"; 

echo decoct(bindec($bin)); // 二 进 制 转换 为 八进制 
echo "<p>"; 

echo "二 进 制 数 ".$bin." 对 应 的 十 六 进 制 数 为 :"; 

echo dechex(bindec($bin)); 1/ 二进制 转换 为 十 六 进 制 
echo "<p>"; 


echo "八进制 数 ".$oct." 对 应 的 二 进 制 数 为 :"; 
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echo decbin(octdec($oct)); /八进制 转换 为 二 进 制 


echo "<p>"; 


echo "八进制 数 ".$oct." 对 应 的 十 六 进 制 数 为 :"; 


echo dechex(octdec($oct)); /八进制 转换 为 二 进 制 


echo "<p>"; 
echo "十 六 进 制 数 ".$hex." 对 应 的 二 进 制 数 为 :"; 


echo decbin(hexdec($hex)); /十 六 进 制 转换 为 二 进 制 


echo "<p>"; 
echo "十 六 进 制 数 ".$hex." 对 应 的 二 八 制 数 为 :"; 


echo decoct(hexdec($hex)); /十 六 进 制 转换 为 八进制 


</body> 
</html> 


保存 以 上 代码 为 “7-8.php”。 在 PHP 执行 环境 中 运行 
以 上 代码 ， 执 行 结果 如 图 7.8 所 示 。 

通过 以 上 实例 及 执行 结果 可 以 发 现 。 虽然 PHP 中 不 能 
实现 二 进 制 、 八 进 制 、 十 六 进 制 之 间 的 直接 转换 。 但 是 通 
过 十 进 制作 为 中 间 变 量 , 还 是 能 方便 地 实现 这 样 的 目的 的 。 

除了 这 6 个 函数 以 外 ，PHP 中 还 有 一 个 函数 : base_ 
convert(string number,Int frombase ,int to base) 可 以 实现 任意 
进 制 之 间 的 转换 。 它 的 返回 值 为 一 字符 串 ， 包 含 Number 
以 Tobase 进 制 的 表示 。Number 本 身 的 进 制 由 frombase 指 
定 。frombase 和 tobase 都 只 能 在 2~36 之 间 ( 包 括 2 和 36)。 
高 于 十 进 制 的 数字 用 字母 a~z 表示 。 如 a 表示 10，b 表示 
11 以 及 z 表 示 35。 

下 面 通过 一 个 实例 来 说 明 如 何 使 用 Base_convert(0 函 数 
来 进行 进 制 转换 。 

<html> 

<head> 


<title>base_convert() 函 数 使 用 实例 </title> 
</head> 


// 定 义 变量 备用 

$bin="11001"; 

$hex="12F"; 

$oct="77"; 

echo "二 进 制 数 ".$bin." 转 为 十 六 进 制 数 为 :"; 
echo base convert($bin,2,16); 

echo "<p>"; 

echo UEMA. $oct." 转 为 二 进 制 数 为 : "; 
echo base_convert($bin,8,2); 

echo "<p>"; 
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二 进 制 数 11001 对 应 的 十 进 制 数 为 ，25 

十 进 制 数 100 对 应 的 二 进 制 数 为 ，1100100 
十 进 制 数 100 对 应 的 八进制 数 为 ，144 

十 进 制 数 100 对 应 的 十 六 进 制 数 为 ，64 
八进制 数 77 对 应 的 十 进 制 数 为 ，53 

十 六 进 制 数 128 对 应 的 十 进 制 数 为 ，303 
二 进 制 数 11001 对 应 的 八进制 数 为 ，31 
二 进 制 数 11001 对 应 的 十 六 进 制 数 为 ，19 
八进制 数 77 对 应 的 二 进 制 数 为 ，111111 
八进制 数 77 对 应 的 十 六 进 制 数 为 ，3f 

十 六 进 制 数 1 对 应 的 二 进 制 数 为 ，100101111 
十 六 进 制 数 128 对 应 的 二 八 制 数 为 ，457 
ar | lL [ meme 


图 7.8” 进 制 转换 函数 使 用 实例 执行 结果 
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echo "十 六 进 制 数 ".$hex." 转 为 八进制 数 为 :"; 


echo base_convert($bin,16,8); 
?> 

</body> 

</html> 


保存 以 上 代码 为 “7-9.php”。 在 PHP 执行 环境 中 
运行 以 上 代码 ， 其 执行 结果 如 图 7.9 所 示 。 


从 执行 结果 中 可 以 发 现 ， 使 用 


base_convert() 函 数 


对 数据 的 进 制 进行 转换 ， 与 使 用 进 制 转换 系列 函数 转 
换 的 结果 一 模 一 样 。 说 明 函 数 正常 运行 。 
这 一 小 节 PHP 中 的 进 制 转换 函数 就 介绍 到 这 里 。 


7.2.6 ”其 他 数学 函数 


TINA 一 crssel 
© EV waw IA ” 以 


二 进 制 数 11001 转 为 十 六 进 钊 数 为 ，19 ju 
八进制 教 77 转 为 二 进 制 数 为 ，1001000000001 
十 六 进 制 数 12F 转 为 八进制 数 为 ，210001 


uo net YA 


图 7.9 base_convert() 函 数 使 用 实例 执行 结果 


除了 以 上 5 小 节 介绍 的 数学 函数 之 外 ，PHP 中 还 有 以 下 几 个 常用 的 数学 函数 : hypot() 函 数 、piO 


函数 等 。 下 面 分 别 为 读者 介绍 。 


hypot(float x, float y) 函 数 ， 计 算 一 直角 三 角形 斜 边 的 长 度 。 返 回 值 为 sqrt(x*x+y*y)。 
piO 函 数 ， 此 函数 无 参数 ， 返 回 圆周 率 的 近似 值 : 3.1415926535898。 当 然 也 可 以 使 用 系统 预定 义 常 


量 : M_PI 来 代替 这 个 函数 。 


这 两 个 函数 的 使 用 方法 相对 单一 ， 下 面 分 别 通过 例子 来 介绍 如 何 使 用 这 两 个 函数 。 


1. hypot0 函 数 使 用 实例 


<html> 

<head> 

<title>hypot() 函 数 使 用 实例 </title> 
</head> 


$b=4; 
echo "直角 三 角形 的 一 直角 边 为 :".$a; 
echo "<br>"; 


echo " 另 一 直角 边 为 ".$b." 则 此 三 角形 的 斜 边 为 :"; 


echo hypot($a,$b); 

echo "<p>"; 

$a=5; 

$b=12; 

echo "直角 三 角形 的 一 直角 边 为 :".$a; 
echo "<br>"; 


echo " 另 一 直角 边 为 ".$b." 则 此 三 角形 的 斜 边 为 : "; 


echo hypot($a,$b); 
人 

</body> 

</html> 


// 定 义 变量 
// 定 义 变 理 


// 计 算 三 角形 斜 边 


// 定 义 变量 
/定义 


第 7 章 PHP 的 数据 处 理 "85。 


保存 以 上 代码 为 “7-10.php”。 在 PHP 执行 环境 中 运行 
以 上 代码 ， 其 执行 结果 如 图 7.10 所 示 : 


从 上 面 的 例子 及 执行 结果 可 见 hypot0 函 数 , 实际 上 是 返 ku 5 
回 了 sqrt($a*$a+$b*$b)。 根 据 数学 中 的 勾 股 定理 ， 实 际 上 就 和 ,13 
是 直角 三 角形 的 斜 边 。 EE E Zi 

2，PpiO 函 数 使 用 实例 7.10 hypot0 函 数 使 用 实例 执行 结果 

<html> 

<head> 

<title>pi() 函 数 使 用 实例 </title> 

</head> 

<body> 

<? 

echo "圆周 率 的 值 为 :"; 

echo pi(); /利用 pi() 函 数 输出 圆周 率 

echo "<p>"; 

$r=10; 

echo "有 一 个 圆 的 半径 为 ".$r"Cm， 则 它 的 周 长 为 : "; 

echo number_format(2*$r*pi(),2)."Cm"; // 计 算 圆 的 周 长 并 格式 化 输出 

echo "<br>"; 

echo "此 圆 的 面积 为 :"; 

echo number_format(pi()*$r*$r,2)." 平 方 Cm"; /1/ 计 算 圆 的 面积 并 格式 化 输出 

?> 

</body> 

</html> 

保存 以 上 代码 为 “7-11.php”。 在 PHP 执行 环境 中 运行 RES 
该 文件 ， 执 行 结果 如 图 7.11 所 示 。 MARWAN: 3.1415926535898 z 

从 以 上 例子 中 可 以 了 解 到 piO 函 数 的 运行 机 理 及 返回 值 AUNA MENU 
情况 。 KASTRA: 314. 16 平 方 Cn É 

至 此 PHP 中 的 数学 函数 就 基本 上 介绍 完了 ，7.3 节 将 会 TT enm 一 
为 读者 介绍 PHP 中 字符 串 处 理 函数 。 图 7.11 pi0 函 数 使 用 实例 执行 结果 


73 PHP 中 常用 的 字符 串 函 数 


字符 串 操 作 的 重要 性 一 点 也 不 亚 于 数学 计算 。 在 PHP 编程 过 程 中 ， 不 管 是 进行 文本 的 处 理 还 是 字 
符 的 操作 都 离 不 开 字 符 串 。 大 量 的 信息 都 是 用 字符 串 来 存储 的 。 所 以 说 只 有 善于 处 理 字符 串 才 能 称 得 
上 是 一 个 合格 的 程序 员 。 这 一 节 来 讲解 PHP 中 常用 的 字符 串 函 数 。 


7.3.1 取得 字符 串 长 度 


要 想 处 理 一 个 字符 串 ， 第 1 步 就 要 了 解 该 字 串 的 长 度 。 在 其 他 一 些 编程 语言 (如 Javascript) 中 ， 
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字符 串 的 长 度 通常 都 是 作为 字符 串 的 一 个 属性 出 现 。 而 PHP 中 则 需要 通过 相应 的 函数 来 取得 ， 这 个 函 
数 就 是 strlen(string)。 

strlen(string) 函 数 ， 取 得 字符 串 的 长 度 。 参 数 string 为 字符 串 变 量 ， 返 回 值 为 表示 字符 串 的 整 型 变 
量 。 空 字符 串 将 返回 “0”。 

下 面 通过 一 个 实例 来 说 明 strlen0) 函 数 是 如 何 起 作用 的 。 

<html> 


<head> 
<title> 取 得 字符 串 的 长 度 </title> 


$s="asdfghjkl"; /定义 字符 串 
$s2="| love this game!"; /定义 字符 串 

echo "字符 串 ".$s." 的 长 度 为 : "; 

echo strlen($s); // 取 得 字符 串 的 长 度 
echo "<P>"; 

echo "字符 串 ".$s2." 的 长 度 为 : "; 

echo strlen($s2); // 取 得 字符 串 的 长 度 
?> 

</body> 

</html> 


保存 以 上 代码 为 “7-12.php”。 在 PHP 执行 环境 中 运 
行 以 上 代码 ， 将 会 看 到 如 图 7.12 所 示 的 执行 结果 。 

在 使 用 strlen() 函 数 时 必须 注意 一 个 问题 ， 当 参数 为 西 
文字 符 时 , 能 正确 返回 字符 串 的 长 度 。 而 当 参 数 为 中 文 时 ， 
就 得 不 到 预想 的 结果 。 一 个 中 文字 符 将 被 当 作 两 个 西 文字 
符 来 处 理 。 所 以 在 使 用 strlen() 函 数 时 要 注意 : 参数 只 能 是 图 7.12 取得 字符 串 的 长 度 实例 执行 结果 
西 文字 符 而 不 能 是 中 文字 符 或 者 含有 中 文字 符 。 
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AKAFA BAKI EE ma 
字符 串 aedfehikl 的 长 度 为 ，9 四 
PRI love this game! 的 长 度 为 ，17 


PHP 中 用 于 输出 字符 串 的 函数 有 以 下 几 种 : 

echo 函数 ， 用 于 字符 串 的 输出 。echo 在 前 面 的 例子 中 已 经 多 次 用 到 过 。 从 严格 意义 上 来 讲 echo 
并 不 是 一 个 真正 的 函数 ， 使 用 的 时 候 ， 不 需要 加 “0”。 另 外 也 没有 返回 值 。 

print(string) 函 数 ， 输 出 字符 串 。 参 数 string 为 字符 串 变量 或 者 常量 。 函 数 返 回 一 个 布尔 值 。 当 执行 
成 功 时 返回 True， 反 之 返回 False。 

printf(string formatmixed[args]) 函 数 ， 将 字符 串 格式 化 输出 。 输 出 格式 依照 参数 format 的 内 容 ， 具 
体内 容 见 下 面 的 sprintfO 格 式 化 字符 串 函数 。 

sprintf(string format,mixed[args]) 函 数 ， 格 式 化 字符 串 。 参 数 format 是 转换 的 格式 ， 以 百分比 符号 % 
开始 到 转换 字符 为 止 。 
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格式 的 内 容 按照 顺序 如 下 。 


O ”填空 字 元 : 0 表示 空格 填 0; 空格 是 内 定 值 。 
O ”对齐 方 式 : 内 定 值 为 向 右 对 齐 ， 负 号 表示 向 左 对 齐 。 
口 ” 栏 位 宽度 : 为 最 小 宽度 。 
O ”精确 度 : 指 在 小 数 点 后 的 浮 点 数位 数 。 
O WS: 如 表 7.5 所 示 有 以 下 几 种 。 
表 7.5 格式 化 字符 串 的 转换 字符 型 态 
Yo 印 出 百分比 符号 不 转换 
b 整数 转 成 二 进 制 
c 整数 转 成 对 应 的 ASCII 字 符 
d 整数 转 成 十 进 制 
f 倍 精 确 度数 字 转 成 浮 点 数 
AA 整数 转 成 八进制 
s 整数 转 成 字 串 
x 整数 转 成 小 写 十 六 进 制 
ï 整数 转 成 大 写 十 六 进 制 
因为 echo 与 print() 函 数 相对 简单 ， 这 里 就 不 多 做 介绍 ， 重 点 来 说 一 下 sprintf0 这 个 格式 化 函数 。 
关于 如 何 使 用 sprintfl) 函 数 ， 先 来 看 一 个 经 典 的 实例 : 
<? 
$money1=68.75; 
$money2-54.35; 
$money=$money1+$money2; // 此 时 变量 $money 值 为 "123.1" 
$formatted=sprintf("%01.2f", $money); // 此 时 变量 $formatted 值 为 "123.10" 
Ti 


上 述 代 码 中 的 “%01.2f” 是 什么 意思 呢 ? 
首先 这 个 “%” 符 号 是 开始 的 意思 ， 它 写 在 最 前 面 表示 指定 格式 要 开始 了 。 也 就 是 “起 始 字符 ”， 


直到 出 现 “ 转 换 字符 ”为 格式 终止。 


然后 跟 在 % 符 号 后 面 的 是 “0”。 这 个 零 是 “填空 字 元 ”， 表 示 如 果 位 置 空 着 就 用 “0” 来 填 满 。 
在 0 后 面 的 是 “1”， 这 个 “1” 是 规定 : 小 数 点 前 面 的 数字 占 位 要 有 1 位 以 上 。 如 果 把 “1” 改 成 


“2”， 则 $formatted 的 值 将 为 “01.23”。 因 为 ， 在 小 数 点 前 面 的 数字 只 占 了 1 位， 按照 上 面 所 规定 的 
格式 ， 小 数 点 前 数字 应 该 占 2 位 ， 现 在 只 有 1 位 ， 所 以 用 “0” 来 填 满 。 


介绍 到 这 里 ， 在 %01 后 面 的 “.2”( 点 2) 就 很 好 理解 了 ， 它 的 意思 是 规定 : 小 数 点 后 的 数字 必须 


占 2 位 。 如 果 这 时 候 $Smoney 的 值 为 “1.234”， 则 $formatted 的 值 将 为 “1.23”。 之 所 以 去 掉 了 最 后 的 


“4”， 是 因为 按照 上 面 的 规定 在 小 数 点 后 面 必须 且 仅 能 占 2 位 。 可 是 Smoney 的 值 中 ， 小 数 点 占 了 3 


位 ， 所 以 最 后 的 “4” 被 去 掉 了 只 剩 下 “23”。 


最 后 ， 以 “f” 这 个 “转换 字符 ”结尾 。 
其 他 转换 字符 请 自行 参考 表 7.5 所 列 出 的 转换 字符 。 
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关于 对 齐 ， 如 果 在 % 起 始 符号 后 面 加 上 “-”《【 和 负 号 ) 则 会 把 数字 以 向 右 对 齐 的 方式 进行 处 理 。 
下 面 通过 一 个 例子 来 说 明 sprintf0 格 式 化 函数 的 使 用 方法 : 


<html> 

<head> 

<title>sprintf() 函 数 使 用 实例 </title> 
</head> 


$s="123.321"; /定义 字符 串 
echo $s." 的 原始 值 : ".$s; 

echo "<p>"; 

$temp=sprintf("%-1.1f",$s); /| 进行 格式 化 
echo $s." 经 过 格式 化 后 的 值 :".$temp; 

echo "<p>"; 

$s="12 3 5"; /定义 字符 串 
echo $s." 的 原始 值 : ".$s; 

echo "<p>"; 

$temp=sprintf("%0-b",$s); /进行 格式 化 
echo $s." 经 过 格式 化 后 的 值 ".$temp; 

?> 

</body> 

</html> 


保存 以 上 代码 为 “7-13.php”。 在 PHP 执行 环境 中 运行 以 上 代码 ， 执 行 结果 如 图 7.13 所 示 。 

具体 分 析 以 上 代码 。 

$s 的 原始 值 为 123.321，“%-1.1f” 表 示 左 对 齐 ， 小数 
点 前 后 各 有 一 位 数字 。 但 小 数 点 前 已 经 有 三 位 了 所 以 保留 
三 位 。 小 数 点 后 面 的 三 位 则 去 掉 后 两 位 保留 一 位 。 

第 2 个 $s 的 原始 值 为 “12 3 5”， 先 去 掉 空格 ， 然 后 
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123. 321 的 原始 入 ，123. 321 
123. 321 经 过 格式 化 后 的 值 ，123. 3 
12 3 5 的 原始 值 , 12 3 5 

12 3 5 经 过 格式 化 后 的 值 1100 


左 对 齐 ， 再 把 得 到 的 十 进 制 整数 转化 为 二 进 制 。 空 格 前 只 _ 上 
有 一 个 12， 所 以 对 12 进行 十 进 制 到 二 进 制 的 转化 ， 结 果 ee 
为 1100， 即 8 (2 的 3 次 方 ) +4 (2 的 二 次 方 ) 。 图 7.13 sprintf) 函 数 使 用 实例 执行 结果 


7.3.3 ”截取 字符 串 


在 进行 字符 串 处 理 的 时 候 ， 有 时 需要 对 字符 串 进 行 截取 。 在 PHP 中 要 做 到 这 一 点 也 是 很 简单 的 ， 
因为 有 一 个 专门 的 函数 供用 户 调用 ， 这 个 函数 就 是 substr()。 

substr(string string,int start,int [length]) 函 数 , 截取 字符 串 。 参 数 string 为 字符 串 变 量 , 参数 start, length 
为 整 型 变量 。 函 数 返 回 字 符 串 string 从 start 开始 的 length 个 字符 。 如 果 length WF, WJA start 截取 到 
字符 串 结束 。 如果 start 为 负数 ， 则 从 字符 串 末 尾 开 始 截 取 。 如 果 length 为 负 则 表示 截取 到 倒数 第 length 
个 字符 。 

下 面 通过 一 个 实例 来 说 明 ， 如 何 使 用 substr0 函 数 来 截取 字符 串 。 
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<html> 

<head> 

<title> 截 取 字符 串 </ttle> 
</head> 


$s="asdfghjkl"; // 定 义 字 符 串 
$s2="| love this game!"; /定义 字符 串 
echo "字符 串 ".$s; 

echo "<br>"; 

echo "从 3 开始 的 5 个 字符 为 : " 

echo substr($s,3,5); /截取 字符 串 
echo "<P>"; 

echo "字符 串 ".$s2; 

echo "<br>"; 

echo "从 2 开始 的 0 个 字符 为 :"; 

echo substr($s2,2); /截取 字符 串 
echo "<p>"; 

echo "字符 串 ".$s2; 

echo "<br>"; 

echo "从 -5 开始 的 字符 为 : "; 

echo substr($s2,-5); /截取 字符 串 
echo "<p>"; 

echo "字符 串 ".$s2; 

echo "<br>"; 

echo "从 2 开始 的 -6 个 字符 为 : "; 

echo substr($s2,2,-6); /截取 字符 串 
?> 

</body> 

</html> 


| 
保存 以 上 代码 为 “7-14.php”。 在 PHP 执行 环境 中 运 2 asifshiki E 
行 以 上 代码 ， 其 执行 结果 将 如 图 7.14 所 示 。 

上 面 代码 中 的 前 两 次 截取 都 很 好 理解 ， 不 多 解释 。 重 PR Tore this core! 
substr(Ss2,-5)， 意 思 是 从 尾 端 截 取 5 个 到 末尾 ， 所 以 返 FHA oyo diz ya 


5i el 
“ 2 开始 的 -个 字符 为，Tove this 
回 “game 


substr($s2,2,-6)， 意 思 是 从 第 2 个 开始 截取 到 倒数 第 6 
个 ， 所 以 返回 “love this”。 图 7.14 截取 字符 串 实例 执行 结果 


asr | [ 


[D erat 


7.34 按 特定 字符 切 开 字符 串 


在 进行 字符 串 操作 过 程 中 , 有 时 需要 把 一 个 较 长 的 字符 串 按照 特定 的 字符 分 割 成 若干 个 短 的 字符 。 
如 文件 本 型 数据 库 ， 通 常 把 一 行当 作 一 条 记录 。 而 一 条 记录 中 则 通过 特定 的 标记 字符 来 分 别 存放 不 同 
的 字段 。 对 这 样 的 记录 ， 操 作 时 就 要 按 这 些 特定 的 标记 字符 把 一 行 记 录 分 割 开 。PHP 中 提供 了 这 样 的 
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函 数 : 
Q explode(string separator,string string[,int limit])， 切 开 字 符 串 函数 。 本 函数 将 字符 串 依 指定 的 字 


符 或 字符 串 separator 分 开 ， 如 果 使 
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T limit 参数 则 返回 的 数组 包含 最 多 limit 个 元 素 ， 而 最 


后 那个 元 素 将 包含 string 的 剩余 部 分 。 函 数 的 返回 值 是 以 返回 字符 串 为 元 素 的 字符 串 数组 。 
口 split(string pattern,string stirng[,int limit)， 用 正则 表达 式 把 字符 串 分 割 到 数组 中 。 本 函数 返回 
一 个 字符 串 数 组 ， 每 个 元 素 为 string 经 区 分 大 小 写 的 正则 表达 式 pattern 作为 边界 分 割 出 的 子 
串 。 如 果 设 定 了 limit, 则 返回 的 数组 最 多 包含 limit 个 元 素 , 而 其 中 最 后 一 个 单元 包含 了 string 
中 剩余 的 所 有 部 分 。 如 果 出 错 ， 则 split0 返 回 False。 
O strtok(string str,string token), 切 开 字符 串 函数 。 本 函数 将 传 回 字 符 串 str 依据 token 的 值 切 成 一 


小 段 一 小 段 的 字符 串 。 


下 面 通过 一 个 实例 来 介绍 这 些 分 割 字符 串 函 数 是 如 何 使 用 的 。 


<html> 

<head> 

<title> 切 开 字符 串 使 用 实例 </title> 
</head> 

<body> 


<? 

$s="123|456|789"; 

$s2="|"; 

echo "字符 串 ".$s; 

echo "<br>"; 

echo "使 用 explode 方法 分 割 开 : "; 
$temp=explode($s2,$s); 
for($i=0;$i<count($temp);$i++) 
echo $temp[$i].", "; 

echo "<P>"; 

echo "字符 串 ".$s; 

echo "<br>"; 

echo "使 用 explode 方法 加 上 参数 2 分 割 开 : "; 
$temp=explode($s2,$s,2); 
for($i=0;$i<count($temp); $i++) 
echo $temp[$i].", "; 

echo "<P>"; 

echo "字符 串 ".$s; 

echo "<br>"; 

echo "使 用 split 方法 分 割 开 : "; 
S$temp=split([|]',$s); 
for($i=0;$i<count($temp);$i++) 
echo $temp[$i]."，"; 

echo "<P>"; 

echo "字符 串 ".$s; 

echo "<br>"; 

echo "使 用 strtok 方法 分 割 开 : "; 
$temp=strtok($s,$s2); 
while($temp) 


/定义 字符 串 
/定义 子 字符 串 


INEM explode 截取 字符 串 
// 循 环 显示 返回 的 数组 元 素 


/使 用 explode 截取 字符 串 
/循环 显示 返回 的 数组 元 素 


/分 割 字符 定义 为 “|” 来 取 字 符 串 
/| 循环 显示 返回 的 元 素 


/使 用 strtok 截取 字符 串 
/循环 显示 分 割 后 的 字符 串 
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{ 
echo $temp.", "; 
S$temp=strtok("|"); 
A DONFASPMEN - Bicresoft Tatere. E] 
bas XFO MBO SFO KEW IAD i”) R 
</html> oE ar, 123, 456, 789, 
保存 以 上 代码 为 “7-15.php”。 在 PHP 执行 环境 中 运 i 123, 4561789, 
行 以 上 代码 ， 将 会 出 现 如 图 7.15 所 示 的 执行 结果 。 ,3, 456, tao, 
从 以 上 代码 的 执行 情况 可 以 看 出 : split0 函 数 需 要 使 用 字符 串 12314561789 
正则 表达 式 规则 而 sttok() 函 数 返 回 的 只 是 字符 串 而 不 是 AAA E 
字符 串 数组 ; 而 使 用 explodeO 函 数 切 开 字符 串 是 3 个 函数 sæ OO l leem 
中 最 简单 易 用 的 。 图 7.15 切 开 字符 串 使 用 实例 执行 结果 


7.3.5 去 除 字符 串 中 的 特殊 符号 


在 进行 实际 PHP 编程 的 时 候 ， 处 理 的 字符 串 有 可 能 是 来 自 于 网 页 中 ,里面 可 能 包含 有 HTML 或 者 
PHP 标记 。 这 时 就 需要 把 它们 去 除 之 后 再 做 处 理 。 在 PHP 中 也 有 专门 除去 字符 串 中 特殊 符号 标记 的 字 
符 串 处 理 函数 : strip_tags()。 

strip tags(string str) 函 数 ， 去 掉 字符 串 参 数 str 中 的 HTML 及 PHP 标记 ， 将 处 理 之 后 的 字符 串 作 为 
函数 的 返回 值 。 

此 函数 可 去 掉 字符 串 中 包含 的 任何 HTML 及 PHP 的 标记 字 串 。 若 是 字 串 的 HTML 及 PHP 标签 原 
来 就 有 错 ， 如 少 了 大 于 号 ， 则 也 会 传 回 错误 。 而 本 函数 和 文件 操作 系列 的 fgetss0 函 数 有 着 相同 的 功能 。 

下 面 通过 一 个 实例 来 说 明 ， 如 何 使 用 strip_tags() 函 数 来 去 除 字符 串 中 的 特殊 标记 。 


<html> 

<head> 

<title> 去 除 字符 串 的 特殊 符号 使 用 实例 </title> 
</head> 


$s="<font color=\"#f0000\W"> 我 爱 北京 天 安 门 ! </font>"; 
$t=strip_tags($s); 

$s2="<font size=\"16pt\"> 天 安 门 上 太阳 升 ! </font>"; 
$t2=strip_tags($s2); 

echo $s; 

echo "<p>"; 

echo $t; 

echo "<p>"; 

echo $s2; 

echo "<p>"; 

echo $t2; 

?> 

</body> 

</html> 
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保存 以 上 代码 为 “7-16.php”。 在 PHP 执行 环境 中 运行 以 上 代码 ， 其 执行 结果 将 会 如 图 7.16 所 示 。 


委 夫 除 字 符 定 的 转 琳 疹 呈 信用 实证 - Microsoft Intern lolxl 
XPO REV ZEV YU IRU EMW | 
我 爱 北京 天 安 门 ! 时 
我 妥 北 京 天安 门 ! 

天 安 门 上 太阳 升 ! 

天 安 门 上 太阳 升 ! 


BE 
图 7.16 去 除 字符 串 的 特殊 符号 使 用 实例 执行 结果 
通过 上 例 发 现 ， 使 用 strip_tags0 函 数 去 除了 原 字符 串 中 的 字体 颜色 和 字体 大 小 的 标识 。 达 到 了 去 
除了 特殊 符号 的 目的 。 


7.3.6 ”转换 字符 串 中 的 特殊 符号 为 HTML 标记 
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编写 Web 互动 网 页 时 ， 安 全 问题 是 一 定 要 考虑 的 。 一 个 不 可 忽略 的 问题 就 是 对 用 户 提交 信息 的 处 
理 。 如 果 用 户 提交 了 恶意 HTML 代码 ， 就 会 影响 到 其 他 用 户 的 使 用 ， 甚 至 会 造成 系统 瘫痪 。 所 以 编写 
互动 Web 网 页 时 ， 出 于 安全 考虑 要 对 用 户 提 交 内 容 中 的 HTML 代码 进行 处 理 。 

在 PHP 中 有 一 个 函数 实现 这 样 的 功能 : 把 用 户 提交 内 容 (字符 串 ) 中 的 特殊 符号 转换 为 HTML 标 
记 。 这 个 函数 就 是 htmlspecialchars()。 

htmlspecialchars(string string) 函 数 ， 实 现 功 能 : 将 字符 串 参 数 String 中 的 特殊 符号 (如 <、>、" 等 ) 
转化 为 HTML 标记 。 其 具体 转换 内 容 如 下 : 

O &， 转 换 成 &amp;。 

O "， 转 换 成 &quot;。 

口 < 转换 成 &lt;。 

O >， 转 换 成 &gt;。 

下 面 通过 一 个 实例 来 说 明 ， 如 何 使 用 htmlspecialchars0) 函 数 对 字符 串 进行 转换 处 理 。 

<html> 

<head> 


<title> 转 换 字符 串 的 特殊 符号 为 HTML 标记 使 用 实例 </title> 


</head> 


$s="<font color=\"#ff0000\"> 我 爱 北 京 天 安 门 ! <font>"; /定义 第 1 个 字符 串 

$t- htmlspecialchars ($s); // 对 第 1 个 字符 串 进 行 处 理 
$s2="<font size=\"16pt\"> 天 安 门 上 太阳 升 ! </font>"; /定义 第 2 个 字符 串 
$t2=htmlspecialchars($s2); // 对 第 2 个 字符 串 进 行 处 理 
/分 别 输出 原 字符 串 及 处 理 过 的 字符 串 以 查看 处 理 的 结果 

echo $s; 

echo "<p>"; 

echo $t; 
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保存 以 上 代码 为 “7-17.php”。 在 PHP 执行 环境 中 运行 以 上 代码 ， 其 执行 结果 将 会 如 图 7.17 所 示 。 
XPD REV FEV KEW IAV MW [3 
我 爱 北京 天 安 门 1 上 四 


<font color=“#ff0000“> 我 妥 北 京 天 安 门 ! </font> 


天 安 门 上 太阳 升 ! 


《font size=”16pt”> 天 安 门 上 大 阳 升 | </font> 


mlm Ec 
图 7.17 转换 字符 串 的 特殊 符号 为 HTML 标记 使 用 实例 执行 结果 


通过 以 上 函数 可 见 htmlspecialchars() 函 数 把 字符 串 中 的 特殊 符号 都 转换 成 了 HTML 标记 。 经 过 这 
样 的 处 理 , 加 入 字符 串 中 的 HTML 代码 都 将 因 被 转化 而 不 能 起 作用 , 这 样 在 客观 上 就 起 到 了 安全 的 效果 。 


7.3.7 ”加 入 去 掉 斜 线 
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在 数据 库 操作 时 ， 如 果 把 未 经 操作 的 单 引 号 写 入 库 里 就 会 使 SQL 语句 发 生 错 误 。 所 以 给 特殊 字符 
加 上 和 斜 线 就 显得 尤为 重要 。 同 理 ， 显 示 的 时 候 就 要 把 入 库 时 加 入 的 反 和 斜 线 去 除 ， 这 样 库 里 的 内 容 才 能 
正常 显示 。 加 入 斜 线 addslashes(string str) 函 数 和 去 除 斜 线 stripslashes(string str) 函 数 在 PHP 里 也 是 经 常 
用 到 的 函数 。 

这 两 个 函数 的 使 用 与 用 户 的 PHP 解释 器 的 设置 有 关 。php.ini 是 PHP 设置 的 核心 文件 。 其 中 的 

magic_quotes_gpc 项 的 开关 对 这 两 个 函数 有 着 直接 的 影响 。 通 常 有 以 下 两 种 情况 : 

O magic_quotes_gpc=on: 可 以 不 对 输入 和 输出 数据 库 的 字符 串 数据 作 addslashes() 和 stripslashes() 
的 操作 ， 数 据 也 会 正常 显示 。 如 果 此 时 对 输入 的 数据 作 了 addslashes0 处 理 ， 那 么 在 输出 的 时 
候 就 必须 使 用 stripslashes() 去 掉 多 余 的 反 斜 杠 。 

口 magic_quotes_gpc=off: 必须 使 用 addslashes() 对 输入 数据 进行 处 理 ， 但 并 不 需要 使 用 
stripslashes() 格 式 化 输出 ， 因 为 addslashes() 并 未 将 反 斜 杠 一 起 写 入 数据 库 ， 只 是 帮助 MySQL 
完成 了 SQL 语句 的 执行 。 

由 于 这 两 个 函数 牵涉 数据 库 的 操作 ， 这 一 节 只 给 出 简单 提示 ， 具 体 数据 库 的 操作 ， 请 参看 本 书 第 

14 RE MySQL 数据 库 。 


7.3.8 两 个 字符 串 的 比较 


两 个 数值 ， 不 论 是 整 型 的 还 是 浮 点 型 的 都 能 够 比较 大 小 。 而 两 个 字符 串 也 可 以 比较 大 小 。 在 PHP 
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中 ， 有 一 个 函数 专门 用 来 比较 字符 串 的 大 小 。 这 个 函数 就 是 strcmpO。 其 使 用 格式 如 下 : 

int strcmp(string str1,string str2) 

参数 strl 与 str2 表示 两 个 字符 串 变 量 ， 函 数 返 回 一 个 整数 。 如 果 strl 大 于 str2 则 返回 正 数 ， 如 果 
strl 小 于 str2 则 返回 负数 ， 如 果 两 个 字符 串 完 全 一 致 即 字符 串 相 等 则 返回 0。 

字符 串 大 小 的 规则 是 : 从 左 向 右 比 较 ， 比 较 同 一 位 置 的 字符 ，ASCI 码 表 中 后 面 的 大 于 前 面 的 ， 
即 9 大 于 1、T 大 于 A。 

下 面 用 一 个 实例 来 说 明 如 何 使 用 strcmp() 函 数 。 

<html> 


<head> 
<title> 比 较 字符 串 的 大 小 函数 使 用 实例 </title> 


$s="abcdefg"; /定义 变量 
$s2="abddefg"; 
$s3="abddefg"; 
echo $s; 
echo "<p>"; 
echo $s2; 
echo "<p>"; 
echo $s3; 
echo "<p>"; 
function bijiao($str1,$str2) /| 基于 strcmp() 函 数 ， 构 造 一 个 函数 
{ 
if(stremp($str1,$str2)>0) // 如 果 第 1 个 字符 串 大 于 第 2 个 即 返回 正 数 
echo $str1." 大 于 ".$str2; 
elseif(stremp($str1, $str2)<0) // 如 果 第 1 个 字符 串 小 于 第 2 个 即 返回 负数 
echo $str1." 小 于 ".$str2; 
else // 如 果 两 个 字符 串 相等 即 返回 0 
echo $str1." 等 于 ".$str2; 
} /lbijiao 函数 结束 
bijiao($s,$s2); /I 调用 自 定义 函数 bijiao 
echo "<p>"; 
bijiao($s2,$s); 
echo "<p>"; 
bijiao($s3,$s2); 
echo "<p>"; 
?> 
</body> 
</html> 
保存 以 上 代码 为 “7-18.php”， 然 后 在 PHP 执行 环境 中 运行 以 上 代码 ， 其 执行 结果 如 图 7.18 所 示 。 
从 以 上 执行 结果 可 见 返回 结果 符合 比较 规则 。 通过 这 个 例子 , 读者 既 能 明白 stremp0 函 数 的 使 用 方 
法 ， 同 时 也 巩固 了 自 定义 函数 使 用 的 知识 。 
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当 比较 字符 审 的 大 小 承 短 使 用 补 例 - Bicrosofi Tai ali 
ZPO SED SEV VRD 工具 四 W le | 


abcdefg 
abddefe 
abddefs 
abcdefg 小 于 ahddefg 
abddefg 大 于 abcdefg 


abddefe 等 于 abddefe 


GE 


图 7.18 比较 字符 串 的 大 小 函数 使 用 实例 执行 结果 


7.3.9 改变 字符 串 的 大 小 写 


[| Ee 


在 进行 字符 串 处 理 的 时 候 ， 有 时 需要 对 字符 串 中 字母 的 大 小 写 进行 转换 。 这 时 就 需要 用 到 
strtolower() 函 数 和 strtoupper() 函 数 。 
口 string strtolower(string str) 函 数 ， 把 字符 串 参 数 str 中 的 所 有 大 写字 母 转换 为 小 写字 母 ， 把 转换 
后 的 新 字符 串 作为 函数 的 返回 值 。 
O string strtoupper(string stD 函 数 ， 把 字符 串 参数 str 中 的 所 有 小 写字 母 转换 为 大 写字 母 ， 把 转换 
后 的 新 字符 串 作为 函数 的 返回 值 。 
下 面 通 过 一 个 实例 来 说 明 如 何 使 用 这 两 个 改变 字符 串 大 小 写 的 函数 。 


<html> 

<head> 

<title> 改 变 字符 串 的 大 小 写 函 数 使 用 实例 </title> 
</head> 


$s="| Love My Great Country!"; // 定 义 变量 
S$temp1=strtolower($s); /| 转换 为 小 写字 母 
$temp2-strtoupper($s); // 转 换 为 大 写字 母 
echo " 原 字符 为 :"; 

echo $s; 

echo "<p>"; 

echo " 原 字符 经 过 strtolower() 处 理 后 的 值 为 :"; 

echo "<br>"; 

echo $temp1; 1/ 打印 结果 

echo "<p>"; 

echo " 原 字符 经 过 strtoupper() 处 理 后 的 值 为 :"; 

echo "<br>"; 

echo $temp2; 1// 打 印 结果 

?> 

</body> 

</html> 
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保存 以 上 代码 为 “7-19.php”。 在 PHP 执行 环境 中 运行 以 上 代码 ， 其 执行 结果 将 会 如 图 7.19 所 示 。 


| 当 改 支 字符 让 的 大 小 写 两 数 使 用 实 王 ”二 6EE Taz 
ZAD RRO FEV KEW IAD WI |P 


原 字 符 为 : I Love ly Great Country! 
原 字符 经 过 strtolower () AURRENA 
i lov 


y great country! 


原 字符 经 过 strtoupper() ABERIN, 
I LOVE WY GREAT COUNTR 


OES CO O 


图 7.19 改变 字符 串 的 大 小 写 函 数 使 用 实例 执行 结果 


查看 以 上 执行 结果 发 现 ， 经 过 strtolower() 函 数 处 理 的 字符 串 内 容 全 变 为 小 写 ; 而 经 过 strtoupper() 
函数 处 理 的 字符 串 内 容 全 变 成 we 从 这 个 例子 及 执行 结果 能 清晰 地 了 解 这 两 个 函数 的 执行 结果 。 


7.3.10 其 他 常用 字符 串 函 数 


除了 以 上 几 小 节 介绍 的 字符 串 处 理 函 数 之 外 ， 在 进行 PHP 编程 及 字符 串 处 理 过 程 中 ， 还 有 其 他 一 
些 常 用 的 字符 串 函 数 。 由 于 相对 于 前 几 小 节 介绍 的 函数 ， 这 些 函 数 使 用 频率 相对 较 低 。 所 以 只 对 它们 
的 使 用 格式 、 参 数 、 返 回 值 等 情况 做 下 简单 介绍 。 
O string chop(string str) 函 数 ， 去 除 字符 串 str 中 的 连续 空白 ， 返 回 值 为 处 理 后 的 字符 串 。 
O string ltrim(string str) 函 数 , 功能 与 chop 类 似 , 也 是 去 除 字符 串 中 的 连续 空白 带 (whitespace) ， 
并 把 处 理 结果 返回 。 
O string md5(string str) 函 数 ， 把 字符 串 str 进行 MD5 加 密 , 并 把 加 密 后 的 字符 串 作 为 函数 的 返回 
值 。 这 个 函数 在 处 理 用 户 的 密码 时 经 常用 到 ， 一 般 是 把 用 户 密 码 经 md5() 函 数 加 密 后 再 入 库 。 
O string nl2br(string strn) 函 数 ,把 字符 串 str 中 的 回 车 换行 转换 为 HTML 标记 中 的 <br>， 并 把 处 理 
结果 返回 。 这 也 是 一 个 很 有 用 的 函数 ， 特 别 是 用 在 用 户 提交 的 内 容 中 存在 换行 时 ， 使 用 这 个 
函数 就 能 保持 用 户 输入 的 格式 。 
口 string str replace(string needle, string str, string haystack) 函 数 ， 函 数 将 字符 串 str 代入 haystack 
字符 串 中 , 将 所 有 的 needle 置换 成 str。 例 如 , 使 用 str_replace("a","b","abcd"), 函数 将 返回 bbcd。 
到 这 里 PHP 中 常用 的 字符 串 处 理 函 数 就 讲解 完了 。 更 多 的 是 需要 平常 的 使 用 ， 只 有 经 常 使 用 才能 
熟练 掌握 这 些 函数 。 


7.4 PHP 中 常用 的 数组 函数 


在 PHP 编程 过 程 中 ， 有 相当 大 的 成 分 是 与 数组 打交道 。 入 库 的 内 容 需 要 纳入 数组 、 统 计 相 关内 容 
要 写 入 数组 等 都 离 不 开 数组 ， 很 多 的 信息 都 是 用 数组 作为 载体 的 。 所 以 数组 的 操作 在 PHP 编程 中 占有 
很 大 的 比重 ， 只 有 熟练 的 操作 数组 才能 熟练 编写 PHP 程序 。 这 一 节 就 来 介绍 PHP 中 常用 的 数组 函数 。 
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7.4.1 新 建 一 个 数组 


既然 要 操作 数组 ， 第 1 步 就 是 要 新 建 一 个 数组 。 新 建 数组 也 有 相关 的 函数 ， 这 个 函数 就 是 array()。 
从 前 面 对 数 组 的 一 些 介绍 中 ,我们 知道 ， 新 建 一 个 数组 通常 有 两 种 方法 : 一 种 是 直接 给 数组 每 个 变量 
赋值 ， 另 一 种 就 是 同时 给 数组 所 有 元 素 赋值 。 而 给 数组 所 有 元 素 同时 赋值 时 就 要 用 到 array() 函 数 。 

array array(.…) 函 数 ， 新 建 一 个 数列 ， 传 回 的 参数 是 数列 形态 。 参 数 可 以 是 带 有 “=> ”运算 符 的 索 
引 。 从 实质 上 来 说 array0) 并 不 算是 一 个 正规 的 函数 ， 它 主要 是 用 来 表示 数组 。 

下 面 通过 一 个 例子 来 说 明 一 下 array0 函 数 的 使 用 ， 同 时 也 复习 一 下 如 何 新 建 一 个 数组 。 

<html> 

<head> 


<title>array() 函 数 使 用 实例 </title> 
</head> 


$temp=array(1,2,3,4,5,6); /定义 数组 Stemp 
S$temp1=array(0=>"zero", 

1=>"one", 

2=>"two", 

3=>"three" 

); /定义 数组 $temp1 
$temp2=array(name=>" 张 三 ", 
Sex=>" 男 "， 

age=>"20" 

六 /定义 数组 Stemp2 
echo $temp[0]; /| 输出 数组 
echo", "; 

echo $temp[1]; 

echo", "; 

echo $temp[2]; 

echo", "; 

echo $temp[3]; 

echo", " 

echo $temp[4]; 

echo", "; 

echo $temp[5]; 

echo", "; 

echo $temp[6]; 

echo "<p>"; 

for($i=0;$i<count($temp1);$i++) /| 循环 输出 数组 
echo $temp1[$i].", "; 

echo "<p>"; 

echo $temp2[name]; /| 输出 数组 

echo "<p>"; 

echo $temp2[sex]; 

echo "<p>"; 
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echo $temp2[age]; 
?> 


F orrir 0 西 妆 使 用 实 汪 一 ierasse aj 
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</body> 了 E 
</html> zerc, one, two, three, 
保存 以 上 代码 为 “7-20.php”。 在 PHP 执行 环境 中 运行 以 

上 代码 ， 执 行 结果 如 图 7.20 所 示 。 
通过 以 上 实例 , 不 仅 使 读者 了 解 了 array0 函 数 的 使 用 方法 ， La 


更 加 深 了 对 如 何 建立 一 个 数组 的 理解 。 
图 7.20 array0 函 数 使 用 实例 执行 结果 


742 ”计算 数组 的 元 素 个 数 


在 对 一 个 数组 操作 之 前 ， 知 道 数组 的 元 素 个 数 是 很 有 必要 的 。 如 要 对 数组 循环 输出 ， 只 有 当知 道 
了 数组 的 元 素 个 数 时 才能 进行 。 在 PHP 中 计算 数组 元 素 个 数 的 方法 非常 简单 , 那 就 是 使 用 count(O) 函 数 。 

int count(mixed var) 函 数 , 参数 可 以 是 数组 或 者 整数 变量 。 如 果 参 数 是 数组 则 传 回 数组 元 素 的 个 数 ; 
如 果 参 数 为 整数 则 分 两 种 情况 : 如 果 整 数 变 量 还 没有 值 则 传 回 “0”， 如 果 已 经 赋值 则 传 回 “1”。 

下 面 通过 一 个 实例 来 说 明 count() 函 数 的 使 用 方法 。 


<html> 
<head> 
<title> 计 算数 组 的 元 素 个 数 实例 </title> 


$arr1[0]="zero"; 

$arr1[1]="one"; 

$arr1[2]="two"; 

$arr1[3]="three"; 

$arr1[4]="four"; 

$arr1[5]="five"; 

$arr1[6]="six"; 

$arr2=array(" 中 国 "," 美 国 "," 俄 罗斯 "," 英 国 ",” 
$i=5; 

$j; 

echo "数组 arr1 的 元 素 个 数 为 : "; 
echo count($arr1); 

echo "<p>"; 

echo "数组 arr2 的 元 素 个 数 为 :"; 
echo count($arr2); 

echo "<p>"; 

echo count($i); 

echo "<p>"; 

echo count($j); 

?> 

</body> 

</html> 


// 定 义 数组 变量 1 


// 定 义 数组 变量 2 
// 定 义 变量 $i 并 赋值 
// 定 义 变量 $j 


1/ 计算 数组 1 元 素 个 数 


// 计 算数 组 2 元 素 个 数 
// 返 回 变量 值 的 情况 


// 返 回 变量 值 的 情况 
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保存 以 上 代码 为 “7-21.php”。 在 PHP 执行 环境 中 运 
行 以 上 代码 ， 看 到 执行 结果 如 图 7.21 所 示 。 

在 PHP 中 还 有 一 个 函数 也 可 以 完成 类 似 的 工作 , 这 个 
函数 是 sizeofO)。 该 函数 也 是 把 数组 作为 函数 的 参数 ， 把 数 
组 元 素 的 个 数 作为 函数 的 返回 值 。 因 为 这 两 个 函数 使 用 方 
法 相同 ， 所 以 这 里 就 不 再 做 过 多 介绍 。 


7.4.3 ”对 数组 排序 及 逆 排 序 


在 实际 PHP 编程 时 ， 有 时 需要 对 数组 进行 排序 。 通常 对 数组 进行 排序 的 方法 有 以 下 几 种 : 冒 泡 法 、 
对 分 法 等 。 但 是 在 PHP 中 对 数组 的 排序 就 变 得 相当 的 简单 ， 因 为 在 PHP 的 数组 操作 函数 中 ， 有 专门 对 
数组 进行 排序 的 函数 。 使 用 该 类 函数 可 以 对 数组 进行 顺序 或 逆序 排列 。 这 两 个 函数 就 是 sort() 函 数 和 


rsort() 函 数 。 分 别 介 绍 如 下 : 


Hiliki 
ET 


Biarri TENRA. T 
数组 arr2 的 元 素 个 数 为 ,5 


1 


o 


as | Ome 


图 7.21 计算 数组 的 元 素 个 数 实例 执行 结果 


DO void sort(array array) 函 数 ， 对 数组 进行 排序 ， 使 数组 按照 从 小 到 大 的 顺序 重新 排列 。 


口 void rsort(array arry) 函 数 ， 和 sort0 函 数 一 样 对 数组 进行 排序 ， 与 sort(0) 函 数 不 同 的 是 rsort() 函 


数 将 使 数组 按 从 大 到 小 的 顺序 重新 排列 。 


下 面 通过 一 个 实例 来 说 明 ， 如 何 使 用 这 两 个 函数 实现 对 数组 进行 排序 操作 。 具 体 代码 如 下 : 


<html> 
<head> 
<title> 对 数组 排序 函数 使 用 实例 </title> 


S$temp=array(5,2,6,4,1,3); 


$temp1=array(" 北 京 "," 南 京 "" 上 海 "," 杭 州 "," 重 庆 "); 


echo "数组 temp 原始 顺序 为 ;"; 
for($i=0;$i<count($temp);$i++) 


echo $tempiS$i).", "; 
} 
echo "<p>"; 
echo "数组 temp 经 sort 函数 处 理 后 的 顺序 为 : "; 
sort($temp); 
for($i=0;$i<count($temp);$i++) 


echo $temp[$i]; 
echo", "; 

} 

echo "<p>"; 


echo "数组 temp 经 rsort 函数 处 理 后 的 顺序 为 : "; 


rsort($temp); 
for($i=0;$i<count($temp);$i++) 


echo $tempf[$i]; 


/定义 数组 Stemp 
/定义 数组 Stemp1 


/通过 循环 打印 原始 数组 


/对 $temp 数组 进行 sort 处 理 
/通过 循环 打印 处 理 过 的 数组 


Ji $temp 数组 进行 rsort 处 理 
// 通 过 循环 打印 处 理 过 的 数组 


"100 PHP 网 络 编程 从 入 门 到 精通 
echo", "; 
3 
echo "<p>"; 
enio T a al " 
echo "<p>"; 


echo "数组 temp1 原始 顺序 为 ;"; 
for($i=0;$i<count($temp1);$i++) 
í 
echo $temp1[$i]; 
echo", "; 
} 
echo "<p>"; 
echo "数组 temp1 经 sort 函数 处 理 后 的 顺序 为 : "; 
sort($temp1); 
for($i=0;$i<count($temp1);$i++) 
í 
echo $temp1[$i]; 
echo", "; 
} 
echo "<p>"; 
echo "数组 temp1 经 rsort 函数 处 理 后 的 顺序 为 : "; 
rsort($temp1); 
for($i=0;$i<count($temp1);$i++) 


echo $temp1[$i]; 
echo", "; 

} 

?> 

</body> 

</html> 


保存 以 上 代码 为 “7-22.php”。 在 PHP 执行 环境 中 运行 以 上 代码 ， 
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/通过 循环 打印 原始 数组 


/对 $temp 数组 进行 sort 处 理 
/通过 循环 打印 处 理 过 的 数组 


/对 $temp 数组 进行 rsort 处 理 
// 通 过 循环 打印 处 理 过 的 数组 


其 执行 结果 将 会 如 图 7.22 所 示 。 


区 


|?) 


数组 temp 原 始 顺 序 为 ，5，2，6，4,，1，3,， 
数组 temp 经 sor: 函 数 处 理 后 的 顺序 为 1, 2 3, 4, 5, 6, 
数组 temp 经 reort 函 数 处 理 后 的 顺序 为 ，6，5，4，3,，2, 1, 


数组 temp1 原 始 顺序 为 ， 北京， 南京 ， 上 海 ， 杭州， 重庆 ， 
数组 temp1 经 sort 函 数 处 理 后 的 顺序 为 北京， 杭州 ， 南 京 ， 上 海 ， 重 天, 


数组 temp1 经 rsort 函 数 处 理 后 的 硕 序 为 ， 重 庆 ， 上 海 ， 走 京 ， 杭 州 ， 北京 , 


Li 
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图 7-22 对 数组 排序 函数 使 用 实例 执行 结果 


通过 函数 执行 结果 可 以 发 现 ， 在 PHP 中 对 数组 进行 排序 是 一 件 很 简单 的 事情 。 
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7.4.4 ”对 数组 进行 自 定义 排序 


有 的 时 候 ， 单 纯 使 用 7.4.3 小 节 介绍 的 sort() 函 数 或 rsort() 函 数 均 不 能 完全 满足 对 数组 排序 的 要 求 。 
如 下 面 的 数组 : 


<? 
$temp=array(" 班 长 "," 无 职务 "," 副 班长 ",* 团 支书 ”); 
?> 


如 果 想 要 实现 这 样 的 排序 : 团 支 书 > 班 长 > 副 班 长 > 无 职务 ,这 时 不 管 是 使 用 sort() 函 数 还 是 使 用 rsort0 
函数 ， 都 不 好 使 。 因 为 这 种 排序 标准 是 自 定义 的 。 出 现 这 种 情况 ， 就 要 使 用 另 一 个 PHP 数组 操作 函数 
usortO 了 o 

void usort(array array,function cmp_function) 函 数 ， 对 数组 进行 排序 ， 使 数组 按照 用 户 自 定义 比较 函 
数 所 规定 的 顺序 重新 排列 。 

下 面 通过 一 个 实例 来 说 明 usort0 函 数 的 使 用 方法 ， 通 过 这 个 例子 来 解决 上 面 提 到 的 问题 。 


<html> 
<head> 
<title> 对 数组 自 定义 排序 函数 使 用 实例 </title> 
</head> 
<body> 
<? 
$temp=array(" 班 长 "" 无 职务 "," 副 班长 "," 团 支书 "," 无 职务 "" 副 班长 "); /定义 数组 Stemp 
function cmp($a,$b) // 自 定义 排序 函数 
if($a==" 团 支书 ") // 第 1 个 参数 为 团 支书 的 情况 
í 
if($b==" 团 支书 ") 
return 0; 
elseif($b==" 班 长 ") 
retum -1; 
elseif($b==" 副 班长 ") 
retum -1; 
else 
retum -1; 
} 
elseif($a==" 班 长 ) // 第 1 个 参数 为 班长 的 情况 
{ 
if($b==" 团 支书 ") 
retum 1; 
else if($b==" 班 长 ") 
retum 0; 
else if($b==" 副 班长 ") 
retum -1; 
else 


retum -1; 
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} 
elseif($a==" 副 班长 ") // 第 1 个 参数 为 副 班长 的 情况 
这 Sb==" 团 支书 ") 
retum 1; 
else if($b==" 班 长 ") 
retum 1; 
else if($b==" 副 班长 ") 
retum 0; 
else 
retum -1; 
} 
else // 第 1 个 参数 为 无 职务 的 情况 
{ 
if($b==" 团 支书 ") 
retum 1; 
else if($b==" 班 长 ") 
retum 1; 
else if($b==" 副 班长 ") 
retum 1; 
else 
retum 0; 
} 
} /根据 不 同情 况 返 回 不 同 的 值 
echo "数组 temp 原始 顺序 为 : "; 
echo "<p>"; 
for($i=0;$i<count($temp);$i++) // 通 过 循环 打印 原始 数组 
echo $tempiS$i).", "; 
} 
usort($temp,"cmp"); // 对 数组 进行 usort 处 理 
echo "<p>"; 
echo "数组 temp 经 过 usort 处 理 过 的 顺序 为 ; "; 
echo "<p>"; 
for($i=0;$i<count($temp);$i++) // 通 过 循环 打印 处 理 过 的 数组 
echo $tempf[$i].", "; 
} 
?> 
</body> 
ame 
pn E| 
保存 以 上 代码 为 “7-23.php”。 在 PHP 执行 环 Sam ANI 
境 中 运行 以 上 代码 , 将 会 看 到 如 图 7.23 所 示 的 执行 EERE EE ERAR ER, 
结果 数组 teap 经 iaeort 处 理 过 的 顺序 为 ， 
H o 


通过 以 上 实例 及 执行 结果 可 见 ， 使 用 usort() 函 TAE. HK. BHK. SHEK. EPS, EPR. 


数 ， 可 以 实现 一 些 自 定义 的 排序 规则 ， 从 而 实现 对 - 
数组 元 素 进行 自 定义 排序 。 图 7.23 对 数组 自 定义 排序 函数 使 用 实例 执行 结果 


Ea [ 


O Dime 


7.4.5 


移动 数组 指针 


第 7 章 PHP 的 数据 处 理 "103。 


经 过 7.4.4 小 节 的 介绍 ， 读 者 了 解 到 数组 有 很 多 元 素 ， 那 么 究竟 数组 当前 元 素 是 哪 一 位 ? 这 里 就 需 
要 指出 一 个 数组 指针 的 问题 。 每 一 个 数组 变量 都 有 一 个 内 部 指针 , 它 指向 当前 的 数组 元 素 。 在 进行 PHP 
编程 中 ， 有 时 需要 对 数组 的 指针 进行 移动 操作 。 在 PHP 库 函 数 中 ， 有 一 组 函数 来 实现 这 一 操作 。 这 些 


函数 有 以 下 儿 种 : 
O current0 函 数 ， 传 回 数组 当前 指针 指向 的 元 素 。 
O end() 函 数 ， 将 数组 的 指针 移动 到 数组 尾部 ， 即 指向 数组 最 后 的 元 素 。 
O next() 函 数 ， 将 数组 的 指针 向 后 移动 一 位 ， 即 指向 当前 的 后 一 个 元 素 。 
O ”prev0 函 数 ， 将 数组 的 指针 向 前 移动 一 位 ， 即 指向 当前 的 前 一 个 元 素 。 
O reset() 函 数 ， 将 数组 的 指针 移动 到 数组 头 部 ， 即 指向 数组 的 第 一 个 元 素 。 
下 面 通过 一 个 实例 来 向 读者 介绍 ， 如 何 使 用 这 些 函 数 来 达到 移动 数组 指针 的 目的 。 具 体内 容 参 看 
以 下 代码 : 
<html> 
<head> 
<title> 移 动 数组 指针 函数 使 用 实例 </title> 
</head> 
<body> 
<? 


$new[0]="zero"; 
S$new[1]="one"; 
$new[2]="two"; 
$new[3]="three"; 
$new[4]="four"; 
$new[5]="five"; 
$new[6]="six"; 
for($i=0;$i<count($new);$i++) /通过 循环 打印 数组 
{ 


} 


echo $new[$i]."，"; 


echo "<p>"; 

echo "指针 当前 指向 :"; 
echo current($new); 
echo "<p>"; 

echo "指针 后 移 一 位 : "; 
next($new); 

echo current($new); 
echo "<p>"; 

echo "指针 移动 尾部 :"; 
end($new); 

echo current($new); 
echo "<p>"; 


echo "指针 前 移 一 位 : "; 


/定义 一 个 数组 以 备用 


/打印 当前 数组 元 素 ， 以 确定 指针 位 置 


/数组 指针 后 移 一 位 
// 查 看 当前 数组 指针 指向 


/把 数组 指针 移动 的 数组 尾部 
/查看 是 否 已 到 尾部 
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prev($new); /把 数组 指针 前 移 一 位 
echo current($new); /查看 指针 指向 情况 
echo "<p>"; 

echo "指针 移动 到 头 部 : "; 

reset($new); /把 数组 指针 指向 头 部 
echo current($new); /查看 是 否 已 到 头 部 


文件 四 MO HEV HRO IAD mM” P 


zero, one, two, three, four, five, six, 
指针 当前 指 同 ，zero 
指针 后 移 一 位 ，one 
指针 移动 必 部 ，six 
指针 前 移 一 位 ， 乒 ve 
指针 移动 到 头 部 ，zcro 
EEEF 


图 7.24 移动 数组 指针 函数 使 用 实例 执行 结果 
下 面 对 以 上 代码 及 执行 结果 做 一 下 简单 分 析 ， 首 先 初始 化 数组 ， 数 组 指针 指向 数组 第 1 个 元 素 ， 
所 以 current0 返 回 数组 的 第 1 个 元 素 zero; 指针 后 移 一 位 则 指向 one; 指针 移动 到 数组 的 尾部 则 指向 最 
后 一 个 元 素 six; 指针 前 移 一 位 则 指向 five; 指针 移动 到 头 部 则 指向 zero, 


Eg CES 


7.4.6 ”获取 数组 当前 元 素 


通过 7.4.5 小 节 对 PHP 中 移动 数组 指针 函数 的 介绍 ， 读 者 知道 要 获得 数组 当前 元 素 ， 可 以 使 用 的 
方法 就 是 使 用 current() 函 数 。 

mixed current(array array) 函 数 的 返回 值 即 为 当前 数组 指针 指向 的 元 素 。 另 外 ， 还 有 一 个 pos() 函 数 ， 
此 函数 实际 上 就 是 currentO) 函 数 ， 两 个 函数 具有 相同 的 参数 、 作 用 及 返回 值 。 通 过 两 个 函数 都 可 以 获得 
数组 当前 的 元 素 。 


7.47 ” 移 去 数组 中 重复 的 值 


如 果 一 个 数组 中 有 大 量 的 数据 ， 在 进行 数组 处 理 的 时 候 ， 将 其 重复 元 余数 据 的 值 移 去 就 显得 很 有 
必要 。 因 为 这 样 可 以 减少 数据 量 ， 从 而 加 快 数据 的 处 理 速度 。 在 PHP 中 有 一 个 函数 其 作用 就 是 移 去 数 
组 中 重复 的 值 ， 这 个 函数 就 是 array_unique()。 

array array_unique(array array) 函 数 ， 移 去 数组 中 重复 的 值 。 将 数组 参数 array 中 重复 的 值 移 去 ， 将 
处 理 过 的 新 数组 作为 函数 的 返回 值 返回 。 下 面 通过 一 个 实例 来 向 大 家 说 明 array_uniqueO) 函 数 的 使 用 方 
法 。 具 体内 容 参见 以 下 代码 : 
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<html> 
<head> 


<title> 移 去 数组 中 重复 的 值 函 数 使 用 实例 </title> 


</head> 


$new[0]="zero"; 
S$new[1]="one"; 
$new[2]="zero"; 
$new[3]="three"; 
$new[4]="zero"; 
Snew[5]="five"; 

S$new[6]="six"; 
for($i=0;$i<count($new);$i++) 


{ 

echo $new[$i].","; 
} 
echo "<p>"; 


$new1=array_unique($new); 
for($i=0;$i<count($new1);$i++) 


echo $new1[$i].", "; 
} 
?> 
</body> 
</html> 


/定义 一 个 数组 以 备用 


/通过 循环 打印 数组 


// 对 数组 进行 去 除 重复 值 处 理 
/通过 循环 打印 新 数组 


保存 以 上 代码 为 “7-25.php”。 在 PHP 执行 环境 中 运行 以 上 代码 ， 其 执行 结果 将 会 如 图 7.25 所 示 。 
Aaaa miera. 
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zero, one, zero, three, zero, five, six, 


. one. 


three. zero. 


E] 
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图 7.25 移 去 数组 中 重复 的 值 函数 使 用 实例 执行 结果 
查看 以 上 代码 及 执行 结果 可 见 ,使 用 array_unique() 函 数 对 数组 进行 操作 , 移 去 了 数组 中 重复 的 值 。 
在 使 用 array_unique() 函 数 时 有 一 点 是 需要 注意 的 ， 即 虽然 去 除了 数组 中 的 重复 值 ， 但 数组 的 键 名 
仍 将 保持 不 变 。 从 以 上 执行 结果 中 就 可 以 看 出 ，S$Snew1[0]、$new1[2] 的 值 为 空 值 但 其 键 名 仍 在 。 


7.4.8 计算 数组 中 所 有 值 出 现 的 


次 数 


在 使 用 数组 时 ， 如 果 一 个 数组 中 有 一 个 或 几 个 重复 的 值 多 次 出 现 ， 那 么 统计 数组 中 值 的 出 现 次 数 


也 是 很 有 必要 的 。 如 将 一 个 班级 所 有 学 和 


的 年 龄 赋值 给 数组 ， 计 算 某 个 年 龄 的 学 生 有 几 人 的 情况 。 这 


时 就 要 用 到 PHP 数组 函数 中 的 array_count_values() 函 数 。 
array array_count values(array array) 函 数 ， 统 计数 组 中 所 有 值 出 现 的 次 数 。 此 函数 返回 一 个 数组 ， 
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该 数组 用 参数 数组 中 的 值 作为 键 名 ， 用 参数 数组 中 该 值 出 现 的 次 数 作为 值 。 
下 面 通过 一 个 实例 来 说 明 此 函数 的 使 用 方法 。 具 体内 容 参见 以 下 代码 : 
<html> 


<head> 
<title> 计 算数 组 中 所 有 值 出 现 的 次 数 函数 使 用 实例 </title> 


$new[0]="zero"; /定义 一 个 数组 以 备用 
S$new[1]="one"; 

$new[2]="zero"; 

$new[3]="zero"; 

S$new[4]="one"; 

$new[5]="two"; 

S$new[6]="zero"; 

for($i=0;$i<count($new);$i++) IRITARE EPRE 


echo $newf[$i].", "; 
} 
echo "<p>"; 
$new1=array_count_values($new); /使 用 array_count_values() 进 行 处 理 
echo "zero 出 现 的 次 数 为 :"; 
echo $new1[zero]; /打印 zero 出 现 的 次 数 
echo "<p>"; 
echo "one 出 现 的 次 数 为 :"; 
echo $new1[one]; /打印 one 出 现 的 次 数 
echo "<p>"; 
echo "two 出 现 的 次 数 为 :"; 
echo $new1[two]; /打印 two 出 现 的 次 数 
7> 
</body> 
</html> 


保存 以 上 代码 为 “7-26.php”。 在 PHP 执行 环境 中 运行 以 上 代码 ， 其 执行 结果 将 会 如 图 7.26 所 示 。 
Sioi 
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zero. one. zero, zero. one, two. zero. 
zcre 出 现 的 次 数 为 :4 
one 出 现 的 次 数 为 ， 2 
two 出 现 的 次 数 为 ，1 


EE emm Z 
图 7.26 计算 数组 中 所 有 值 出 现 的 次 数 函数 使 用 实例 执行 结果 


查看 以 上 代码 及 执行 结果 可 见 , 通过 array count values0 函 数 , 返回 了 原 数组 中 的 值 及 值 出 现 的 次 
数 作为 新 数组 ， 从 而 实现 了 对 数组 中 值 出 现 次 数 的 统计 。 
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7.4.9 合并 多 个 数组 


实际 进行 PHP 编程 时 ， 对 多 个 相关 的 或 者 类 型 相同 的 数组 进行 操作 ， 其 复杂 程度 要 远 比 对 一 个 数 
组 进行 操作 大 。 所 以 如 果 能 把 多 个 数组 合并 为 一 个 数组 ， 就 能 起 到 简化 操作 的 目的 。 库 函数 功能 丰富 
的 PHP 编程 环境 也 为 用 户 准 备 了 这 样 的 函数 ， 这 个 函数 就 是 array_merge()。 

array array merge(array arrayl,array array2,array array3……- ) 函 数 ， 此 函数 将 对 作为 函数 参数 的 多 个 
数组 进行 合并 。 一 个 数组 中 的 值 附 加 在 前 一 个 数组 后 面 ， 把 合并 后 的 新 数组 作为 函数 的 返回 值 。 

在 使 用 此 函数 时 有 一 点 需要 注意 ， 如 果 两 个 数组 中 存在 相同 的 字符 键 名 ， 那 么 后 一 个 数组 中 的 同 
键 名 的 值 ， 将 替换 前 一 个 数组 中 相应 元 素 的 值 。 代 码 如 下 : 

$a=array(a=>"a",b=>"b",c=>"c"); 

$b=array(a=>"d",b=>"e",c=>"f"); 

对 以 上 两 个 数组 进行 合并 ， 数 组 $b 中 的 元 素 $b[a]、$b[b]、S$b[c] 将 蔡 代 数组 $a 中 相应 的 元 素 。 

如 果 是 相同 的 数字 键 值 ， 并 不 会 出 现 这 样 的 操作 ， 即 后 一 个 数组 的 值 替 换 前 一 个 数组 中 的 值 。 代 
码 如 下 : 

$a=array("a","b","c"); 

$b=array("d","e","f"); 

对 这 两 个 数组 进行 合并 , 因为 它们 都 是 以 数字 作为 键 值 , 如 Sa[0]="a"、$b[0]="d"、…… 、 $a[2]="c"、 
$b[2]="f'。 这 样 的 合并 ， 并 不 会 出 现 值 替代 的 情况 。 数 组 $b 中 的 元 素 ， 将 作为 新 的 元 素 加 入 到 新 合并 
的 数组 中 。 

下 面 通过 一 个 实例 来 说 明 array_mergeO 函 数 的 使 用 方法 。 有 具体 内 容 参 看 以 下 代码 : 

<html> 

<head> 


<title> 合 并 多 个 数组 函数 使 用 实例 </title> 
</head> 


$a=array(1,2,3,4,5,6); // 定 义 数组 $a 
$b=array(7,8,9,10,11); // 定 义 数组 $b 
echo "数组 a 的 内 容 为 :"; 

for($i=0;$i<count($a);$i++) // 循 环 打印 数组 $a 


echo $af$i].", "; 
} 
echo "<p>"; 
echo "数组 b 的 内 容 为 :"; 
for($i=0;$i<count($b);$i++) // 循 环 打印 数组 $b 


echo $b[$i].", "; 
} 


echo "<p>"; 
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$c=array_merge($a,$b); /对 两 个 数组 进行 合并 
echo "合并 后 的 数组 c 的 内 容 为 : "; 
for($i=0;$i<count($c);$i++) // 循 环 打印 合并 后 的 数组 
{ 

echo $c[$i].", "; 
} 
echo "<p>"; 


$str1=array( 

name=>" 张 三 "， 

sex=>" 男 ", 

length=>"170CM" 

Ji /定义 数组 $str1 
$str2=array( 

name=>" 李 四 "， 
birthday=>"5 月 13 号 
length=>"175CM" 

); 1/ 定义 数组 $str2 

echo "数组 str1 的 内 容 为 :"; 

print_r($str1); /格式 化 显示 $str1 的 内 容 
echo "<p>"; 

echo "数组 str2 的 内 容 为 : "; 

print_r($str2); /格式 化 显示 $str2 的 内 容 
$str3=array_merge($str1,$str2); /对 两 个 数组 进行 合并 
echo "<p>"; 

echo "合并 后 的 数组 str3 的 内 容 为 :"; 

print_r($str3); /格式 化 显示 合并 后 的 数组 
?> 

</body> 

</html> 


保存 以 上 代码 为 “7-27.php”。 然 后 在 PHP 执行 环境 中 运行 以 上 代码 ， 其 执行 结果 将 会 如 图 7.27 
所 示 。 


DANI BUREEE -Microsoft Internet TIO | 
aka MBD SEV IW IAD Mho 可 
数组 a 的 内 容 为 : 1，2，3，4，5，6， F 
数组 b 的 内 容 为 ， 7，8，9，10，11， 

AGRENA, 1, 2. 3, 4. 5, 6. 7. 8, 9, 10, 
数组 str1 的 内 容 为 : i ( [name] => 张 三 [sex] > B 

[length] => 17008 ) 

数组 str2 的 内 容 为 ，Array ( [nane] => ÆN [birthday] => 

5 月 13 号 [length] => 1750% ) 

AHER Astr, Array ( [name] => ga [sex] 

> B [length] => 17508 [birthday] => 5 月 13 号 
习 
图 7.27 合并 多 个 数组 函数 使 用 实例 执行 结果 
查看 以 上 实例 及 执行 结果 可 见 ， 通 过 array_merge() 函 数 ， 将 多 个 数组 进行 了 合并 。 并 且 其 遵循 这 


样 的 规则 : 新 的 字符 键 值 的 值 蔡 换 以 前 的 字符 键 值 的 值 ， 而 数字 键 值 的 值 只 作为 新 值 累加 。 
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74.10 其 他 常用 数组 函数 


在 实际 使 用 PHP 进行 网 络 编程 的 过 程 中 , 除了 以 上 介绍 的 数组 函数 之 外 还 有 以 下 常用 的 PHP 数组 
函数 。 由 于 这 些 函 数 使 用 频率 相对 于 前 几 小 节 介绍 的 函数 较 低 ， 所 以 只 作 简单 介绍 而 不 再 举 实例 了 。 

O ”bool in array(mixed needle, array haystack |, bool strict]) 函 数 。 在 haystack 中 搜索 needle， 如 果 
找到 则 返回 True， 否 则 返回 Falses 

O bool ksort(array &array [, int sort_flags]) 函 数 。 对 数组 的 键 名 进行 排序 , 保留 键 名 到 数据 的 关联 。 

O bool natcasesort(array &array) 函 数 。 用 自然 排序 法 〈 及 按照 从 小 到 大 的 顺序 进行 排序 ) ， 对 数 
组 进行 不 区 分 大 小 写字 母 的 排序 。 并 把 排 好 的 结果 作为 函数 返回 值 。 

PHP 中 常用 的 数组 函数 就 介绍 到 这 里 ， 更 多 的 内 容 请 参考 相关 手册 ， 通 过 实践 来 提高 能 力 。 


7.5 本 章 小 结 


这 一 章 为 读者 介绍 了 PHP 的 数据 处 理 , 包括 PHP 中 常用 的 数学 函数 、 字 符 串 函数 、 数 组 函数 等 内 
容 。 熟 练 掌握 并 在 实际 工作 中 运用 这 些 函数 对 数据 的 操作 ， 将 起 到 事半功倍 的 效果 。 数 据 处 理 是 编 
写 大 型 Web 应 用 程序 的 基础 ， 只 有 正确 地 对 数据 进行 相应 的 处 理 ， 才 能 为 大 型 应 用 程序 提供 基础 数据 
支持 。 
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使 用 PHP 打开 文件 
使 用 PHP 该 取 文 件 内 容 
RA PHP 山 除 文件 
PHP 对 目录 的 操作 
甘于 文件 上 传 


aa aaa 


文件 操作 在 PHP 编程 中 占有 很 重要 的 地 位 。 在 很 多 情况 下 ， 用 户 都 要 对 文件 进行 
操作 ， 如 文本 计数 器 、 文 本 留言 板 、 文 件 管理 系统 甚至 是 文本 数据 库 等 。 本 章 将 详细 介 
绍 在 PHP 中 如 何 判 断 文件 是 否 存在 、 如 何 获取 文件 属性 、 如 何 读 取 文 件 内 容 、 如 何 对 
目录 进行 操作 等 文件 操作 。 通 过 对 本 章 的 学 习 ， 将 使 读者 对 如 何 使 用 PHP 进行 文件 操 
作 有 一 个 全 面 的 认识 。 
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8.1 判断 文件 是 否 存在 


在 对 一 个 文件 进行 操作 之 前 ， 判 断 该 文件 是 否 存 在 是 必要 的 。 如 果 用 不 恰当 的 方法 打开 一 个 并 不 
存在 的 文件 ,就 会 导致 错误 .在 PHP 中 有 一 个 专门 的 函数 来 做 这 项 工作 ,这 个 函数 就 是 file_exists(string)。 
参数 string 为 一 个 指向 文件 或 目录 的 字符 型 变量 ， 函 数 的 返回 值 为 布尔 型 变量 ， 如 果 文 件 或 目录 存在 ， 
返回 值 为 True， 反 之 则 返回 False。 下 面 用 一 个 简单 的 例子 来 说 明 这 个 问题 。 代 码 如 下 : 


<html> 

<head> 

<title>file_exists() 函 数 使 用 实例 </title> 

</head> 

<body> 

<? //file_exists() 使 用 实例 
S$filename="data.txt"; // 定 义 变量 
if(file_exists($filename)) // 如 果 文件 存在 时 执行 操作 


echo "指定 文件 ".$filename." 存 在 "; 


} 
else // 如 果 文 件 不 存在 时 执行 操作 


echo "指定 文件 ".$filename." 不 存在 ! "; 
7 


?> 
</body> 
</html> 


保存 以 上 代码 为 “8-1.php”。 在 PHP 执行 环境 中 运行 该 文件 ， 如 果 在 该 文件 (8-1.php〉 同 名 目录 
下 有 data.txt 文件 ， 则 会 返回 “文件 存在 ”; 反之 ， 则 会 返回 “文件 不 存在 ”。 

通过 上 面 的 例子 ， 读 者 可 以 清晰 地 认识 到 file_exists0 函 数 是 如 何 使 用 的 。 

不 过 ， 有 一 个 问题 需要 读者 注意 ， 基 于 安全 考虑 ， 大 多 数 的 文件 操作 类 函数 的 文件 名 参数 不 能 为 
远程 文件 ， 即 只 能 通过 服务 器 的 文件 系统 访问 。 其 中 包括 本 节 的 file_exists() 函 数 及 8.2 节 将 要 介绍 的 
函数 。 例 如 这 样 的 引用 : file_exists("http://www.sohu.com/index.mdb") (其 实 并 不 存在 该 文件 ) ， 不 论 
文件 存在 与 否 都 将 返回 False 值 。 


82 访问 文件 属性 


在 进行 编程 的 时 候 ， 需 要 使 用 到 文件 的 一 些 常见 属性 ， 如 文件 的 大 小 、 文 件 的 类 型 、 文 件 的 修改 
时 间 、 文 件 的 访问 时 间 和 文件 的 权限 等 。 通 过 本 节 的 学 习 ， 将 会 掌握 使 用 PHP 的 相关 文件 函数 。 要 获 
得 这 些 属性 ， 就 如 同 <?echo "hello! world"?> 一 样 简单 。 

具体 内 容 请 参考 表 8.1。 


第 8 章 ”PHP 文件 应 用 113 


表 8.1 文件 属性 相关 函数 


参数 及 返回 值 
参数 string 为 一 个 指向 文件 或 目录 的 字符 型 变量 。 函 数 的 返回 值 为 整 型 变 
量 ， 返 回 文件 的 大 小 〈 字 节 ) 。 如 果 出 错 ， 则 返回 False。 函 数 参数 不 能 为 
远程 文件 ， 返 回 结果 会 被 缓存 
参数 string 为 一 个 指向 文件 或 目录 的 字符 型 变量 。 函数 的 返回 值 为 字符 型 变 
量 ,， 可 能 出 现 的 值 有 fifo、char、dir、block、link、file 和 unknown， 返 回 值 
会 被 缓存 
参数 string 为 一 个 指向 文件 或 目录 的 字符 型 变量 。 函 数 的 返回 值 为 整 型 变 
量 ， 返 回 文件 的 修改 时 间 
参数 string 为 一 个 指向 文件 或 目录 的 字符 型 变量 。 返回 值 为 整 型 变量 ,内容 
为 文件 的 访问 时 间 
参数 string 为 一 个 指向 文件 或 目录 的 字符 型 变量 。 返回 值 为 整 型 变量 ， 内 容 
为 文件 相应 的 权限 ， 同 其 他 这 一 类 型 的 函数 一 样 ， 参 数 不 能 为 远程 文件 ， 
另外 返回 结果 同样 会 被 缓存 


函 数 名 作 用 


filesize(string) 获取 文件 的 大 小 


filetype(string) 获取 文件 的 类 型 


filemtime(string) | 获取 文件 的 修改 时 间 


fileatime(string) | 获取 文件 的 访问 时 间 


fileperms(string) | 获取 文件 的 权限 


下 面 通 过 一 个 简单 的 例子 来 实际 使 用 这 些 函 数 。 注 意 ， 在 使 用 这 个 例子 之 前 ， 要 保证 同 级 目录 下 
有 data.txt 这 个 文件 。 代 码 如 下 : 


<html> 

<head> 

<title> 访 问 文件 属性 函数 使 用 实例 </title> 

</head> 

<body> 

<? // 获 取 文件 属性 使 用 实例 
$filename="data.txt"; /定义 变量 

echo $filename." 的 大 小 为 :" .filesize($filename)."<br>"; MMEA filesize() 函 数 
echo $filename." 的 类 型 为 :" .filetype(S$filename)."<br>"; /使 用 filetype() 函 数 
/使 用 flemtime() 函 数 并 格式 化 返回 日 期 

echo $filename." 的 修改 时 间 为 :".date("Y 年 n A t 日 ",filemtime($filename))."<br>"; 
// 使 用 fileatime() 函 数 并 格式 化 返回 日 期 

echo $filename." 的 访问 时 间 为 :".date("Y 年 n 月 t A" fileatime($filename))."<br>"; 
/使 用 fileperms() 函 数 

echo $filename." 的 权限 为 : "fileperms($filename)."<br>"; 

?> 

</body> 

</html> 


i Po T EPE ziali 
把 以 上 代码 保存 为 “8-2.php”。 在 PHP 执行 环境 中 执行 以 上 。。 [we MER ato PRO L7 A 


代码 ， 执 行 结果 如 图 8.1 所 示 (当然 会 因为 文件 datatxt 的 不 同 ， ata tt 的 大 小 为 12 z 
得 出 结果 有 所 不 同 ) 。 6 和 Fs 月 31 


修改 2 
data, txt 的 访问 时 间 为 ，2006 年 8 月 31 日 


读者 从 这 个 例子 中 可 以 看 到 ， 使 用 PHP 文件 相关 函数 获得 文 。 | ss rnt 加 3520 
件 属性 是 一 件 很 简单 的 事情 。 I e 
图 8.1 访问 文件 属性 


加 
WA 


PFE PHP 网 络 编程 从 入 门 到 精通 


83 打开 文件 


要 使 用 一 个 文件 ,第 一 件 事 就 是 要 把 文件 打开 。PHP 中 提供 了 一 个 很 有 用 的 库 函 数 :fopen(string file , 
string mode)， 它 的 作用 就 是 打开 本 地 或 者 远程 文件 。 参 数 filename 为 一 个 字符 型 变量 ， 代 表 想 要 打开 
的 文件 的 文件 名 ; 参数 mode 为 打开 模式 ， 可 选 的 参数 有 6 个 ， 分 别 是 r、r+、w、w+、a 和 a+。 根 据 
所 选 参数 的 不 同 ， 又 可 以 分 为 以 下 几 种 不 同 的 打开 类 型 。 


8.3.1 用 只 读 方式 打开 文件 


用 只 读 方 式 打开 文件 使 用 :fopen(string file,"r") 函 数 。 参 数 r 使 打开 模式 为 只 读 ， 文 件 指针 指向 文 
件 开头 处 。 这 样 打开 的 文件 ， 不 能 被 写 入 。 下 面 通过 一 个 实例 来 说 明 。 代 码 如 下 : 


<html> 

<head> 

<title>fopen() 函 数 使 用 实例 </title> 
</head> 


//fopen() 使 用 实例 

S$filename="data.txt"; // 定 义 变量 
INEM fopen() 函 数 打开 文 件 

1/ 并且 使 用 “r” 参 数 设置 打开 模式 为 只 读 
$myfile=fopen($filename,"r"); 


fwrite($myfile, "hello world!"); // 试 图 进行 写 入 操作 
fclose($myfile); /| 关闭 打开 的 文件 
?> 

</body> 

</html> 


把 以 上 代码 保存 为 “8-3.php” 文 件 。 在 PHP 运行 环境 中 执行 以 上 代码 ， 会 发 现 fwrite()( 对 文件 进 
行 写 入 操作 ) 这 一 句 并 没有 被 执行 。 打 开 文 件 data.txt 会 发 现 ， 里 面 也 并 没有 多 出 “hello world!” 字 符 
串 。 这 是 因为 Smyfile 句柄 的 打开 方式 为 只 读 ， 所 以 不 能 进行 写 入 操作 。 


8.3.2 用 写 入 方式 打开 文件 


用 写 入 方式 打开 文件 :fopen(string file,"w") 和 fopen(string file,"a")。 参 数 w、a 使 打开 模式 为 写 入 ， 
这 样 打开 的 文件 能 够 被 写 入 。 另 外 ， 使 用 这 两 个 参数 ， 当 文件 不 存在 时 ， 能 自动 创建 文件 。 两 者 的 不 
同 在 于 ， 使 用 参数 w， 文 件 指针 指向 文件 开始 处 并 将 原文 件 清 空 (所 以 这 是 一 个 很 危险 的 参数 ， 除 非 
认为 原来 的 内 容 没 用 了 ， 和 否则 不 要 使 用 此 参数 ) ; 而 使 用 参数 a 则 使 文件 指针 指向 文件 结尾 而 且 不 会 
清空 原文 件 内 容 。 这 里 仍 通过 8.3.1 小 节 的 实例 来 说 明 ， 不 同 的 是 ， 把 其 中 的 替换 为 w。 
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<html> 

<head> 

<title>fopen() 函 数 使 用 实例 2</title> 
</head> 


<? 

/fopen() 使 用 实例 
$filename-"data.tkt"; 

/使 用 fopen() 函 数 打开 文件 
/并 且 使 用 “w” 参 数 设置 打开 模式 为 写 入 
$myfile=fopen($filename,"w"); 
fwrite($myfile,"hello world!"); 
fgets($myfile,255); 
fclose($myfile); 

?> 

</body> 

</html> 
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// 定 义 变 量 


// 试 图 进行 写 入 操作 
// 进 行 读 取 操作 
1/ 关闭 打开 的 文件 


保存 以 上 代码 为 “8-4.php” 文 件 。 在 PHP 运行 环境 中 执行 以 上 代码 ， 然 后 打开 文件 data.txt， 发 现 
里 面 多 出 了 “hello world!” 字 符 串 ， 则 说 明 fwrite0 这 句 对 文件 进行 写 入 操作 的 语句 被 执行 了 。 但 是 以 
写 入 方式 打开 的 文件 只 能 被 写 入 而 不 能 通过 fgetc() 和 fgets0 等 函数 来 读 取 文件 的 内 容 。 如 上 例 中 的 
fgets() 语 句 就 没有 被 顺利 执行 。 

通过 这 两 个 例子 ， 相 信 读 者 对 文件 的 只 读 与 写 入 这 两 种 打开 方式 的 不 同 有 了 深刻 体会 。 


8.3.3 用 读 写 方式 打开 文件 


用 读 写 方式 打开 文件 : fopen(string file,"r+")、fopen(string file,"w+") 和 fopen(string file,"a+")。 参 数 
r+、w+、a+ 使 打开 模式 为 读 写 ， 这 样 打开 的 文件 ， 既 能 够 被 读 取 也 能 够 被 号 入 。 但 是 3 个 参数 也 是 有 
所 不 同 的 。 如 下 : 

O 参数 “r+” 文 件 指针 指向 文件 开头 。 

O 参数 “w+” 文 件 指针 指向 文件 末尾 并 清空 原文 件 。 

O ”参数 “a+” 与 “w+” 基 本 类 似 ， 不 同 的 是 它 并 不 清空 原文 件 。 

继续 用 实例 来 说 明 它们 。 代 码 如 下 : 

<html> 

<head> 


<title>fopen() 函 数 使 用 实例 3</title> 
</head> 


//fopen() 使 用 实例 

$filename="data.txt"; 

/使 用 fopen() 函 数 打开 文件 

1/ 并且 使 用 “r+” 参 数 设置 打开 模式 为 读 写 
$myfile=fopen($filename,"r+"); 
fwrite($myfile, "hello world!"); 


// 定 义 变量 


// 试 图 进行 写 入 操作 
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fgets($myfile,255); // 进 行 读 取 操作 
fclose($myfile); /关闭 打开 的 文件 
?> 

</body> 

</html> 


把 以 上 代码 保存 为 “8-5.php”。 在 PHP 运行 环境 中 执行 以 上 代码 , 打开 页 面 中 显示 出 了 hello world!。 
然后 打开 文件 data.txt 会 发 现 , 里 面 多 出 了 “hello world!” 字符 串 ， 说 明 对 文件 的 读 写 操作 均 被 正确 执行 。 
下 面 通过 表 8.2 来 说 明 这 6 个 参数 的 异同 。 


表 8.2 文件 打开 方式 的 异同 


是 否 清空 原文 件 内 容 
文件 不 存在 是 否 创建 


8.4 读 取 文 件 内 容 


打开 文件 后 就 要 读 取 文 件 的 内 容 了 。PHP 的 文件 函数 提供 了 多 种 方法 来 完成 这 一 任务 。 有 读 取 单 
个 字符 的 fgetc0 函 数 和 读 取 文件 某 一 行 信息 的 fgets() 函 数 和 读 取 整 个 文件 内 容 的 file() 函 数 等 。 本 节 将 
详细 介绍 在 PHP 编程 环境 中 如 何 读 取 文件 内 容 。 在 介绍 本 节 内 容 之 前 , 首先 在 有 PHP 运行 权限 的 目录 
内 建立 “data.txt” 文 件 ， 并 输入 以 下 内 容 : 


<html> 

<head> 
<title> 读 取 文 件 内 容 </title> 
</head> 

<body> 

读 取 文 件 内 容 

<p> 

<u> 读 取 文 件 内 容 </u> 
</body> 

</html> 


以 备 后 用 。 


8.4.1 读 取 文件 相应 字符 


如 果 只 读 取 一 个 文件 中 的 某 一 个 字符 ， 使 用 feetc(int fp) 是 很 方 使 的 。 该 函数 的 参数 fp 是 已 经 被 打 
开 的 文件 句柄 ， 函 数 返回 当前 文件 指针 所 指向 的 字符 。 如 果 文件 指针 指向 文件 末尾 ， 则 返回 False。 这 
里 通过 一 个 例子 来 说 明 fgetc(O) 函 数 的 使 用 方法 。 代 码 如 下 : 
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<html> 

<head> 

<title>fgetc() 函 数 使 用 实例 </title> 
</head> 


// 打 开 文 件 的 同时 读 取 文件 指针 指向 的 字符 
$myfile=fopen("data.txt","r"); 
$mychar=fgetc($myfile); 

echo $mychar; 

fclose($myfile); 

?> 

</body> 

</html> 


/用 只 读 打开 文件 文件 指针 指向 文件 开头 

/用 fgetc() 读 取 文 件 指针 处 字符 并 赋值 给 变量 
// 显 示 变 量 

/关闭 打开 的 文件 


把 以 上 代码 保存 为 “8-6.php” 文 件 。 在 PHP 运行 环境 中 执行 以 上 代码 ， 将 返回 “<”。 因 为 文件 
指针 指向 文件 头 ， 指 针 处 内 容 赋值 给 变量 。 下 面 对 以 上 代码 做 些 改动 ， 通 过 循环 读 取 文 件 所 有 内 容 。 


代码 如 下 : 


<html> 

<head> 

<title>fgetc() 函 数 使 用 实例 2</title> 
</head> 


// 通 循环 读 取 文 件 所 有 内 容 
Smyfile=fopen("data.txt","r"); 
while(!feof($myfile)) 


{ 
$mychar=fgetc($myfile); 
echo $mychar; 


i 

?> 

</body> 

</html> 

把 代码 保存 为 “8-7.php”。 执 行 该 PHP 文件 ， 执 行 
结果 如 图 8.2 所 示 。 

查看 打开 页 的 源 文件 ， 会 发 现 内 容 与 data.txt 完全 一 
样 ， 说 明文 件 内 容 被 正确 读 取 。 这 里 顺便 提 一 下 feofO) 函 
数 , 它 的 作用 就 是 判断 文件 指针 是 否 指 向 文件 末尾 ， 如 果 
已 经 指向 文件 末尾 ， 返 回 Tme， 反 之 则 返回 False. 


8.4.2 按 行 返回 文件 内 容 


如 果 需 要 按 行 读 取 文件 内 容 ， 使 用 fgets(int 印 ,inb 函 数 


// 用 只 读 打开 文件 文件 指针 指向 文件 开头 
// 通 过 循环 判断 指针 是 否 指向 文件 末尾 


/用 fgetc() 读 取 文 件 指针 处 字符 并 赋值 给 变量 
// 显 示 变 量 


// 关 闭 打开 的 文件 


zi 
IS AAA T O eae yA 


8.2 通过 循环 使 用 fgetc0 读 取 文件 内 容 


。 和 fgetc0 函 数 一 样 ， 全 参数 是 已 经 被 打开 
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的 文件 句柄 ， 第 2 个 int 参数 为 要 读 取 字 符 的 个 数 。 函 数 返 回 当前 文件 指针 所 指向 行 指定 的 字符 个 数 。 
如 果 文 件 指针 指向 文件 末尾 ， 则 返回 False。 下 面 通过 一 个 例子 来 说 明 该 函数 的 使 用 方法 。 代 码 如 下 : 


<html> 

<head> 

<title>fgets() 函 数 使 用 实例 </title> 
</head> 


// 打 开 文 件 的 同时 读 取 文件 指针 指向 的 行 

$myfile=fopen("data.txt","r"); /用 只 读 打开 文件 ， 文 件 指针 指向 文件 开头 
$myline=fgets($myfile,255); WA fgets() 读 取 文 件 指针 处 行 并 赋值 给 变量 
echo $myline; /显示 变量 

fclose($myfile); 1/ 关闭 打开 的 文件 

?> 

</body> 

</html> 


保存 上 面 代码 为 “8-8.php”。 在 PHP 运行 环境 中 执行 以 上 代码 ， 会 发 现 什么 也 没有 ， 但 查看 源 文 
件 会 发 现 “<html>”。 因 为 文件 指针 指向 文件 头 ， 指 针 指向 的 行为 第 一 行 ， 即 “<html>” 赋 值 给 了 变 
量 。 同 人 getc0 一 样 ，fgetsO 也 可 以 通过 循环 来 实现 显示 文件 全 部 内 容 ， 这 里 就 不 再 袭 述 。 


8.4.3 按 行 返回 文件 内 容 去 除 HTML 标记 


有 时 返回 文件 指定 行 的 内 容 同时 需要 去 除 掉 html 标记 , 这 时 使 用 fgetss(int fp,inb 函 数 就 很 方便 了 。 
函数 使 用 方法 与 fgets() 相 同 ， 不 同 的 是 函数 返回 行内 容 的 同时 去 除 htm 标记 。 同 样 使 用 例子 来 说 明 这 
个 函数 的 使 用 。 这 次 直接 使 用 循环 来 读 取 文件 所 有 内 容 。 代 码 如 下 : 

<html> 

<head> 


<title>fgetss() 函 数 使 用 实例 </title> 
</head> 


// 打 开 文 件 的 同时 读 取 文件 指针 指向 的 行 
$myfile=fopen("data.txt","r"); // 用 只 读 打 开 文件 文件 指针 指向 文件 开头 
while(!feof($myfile)) 


{ 
$myline=fgetss($myfile,255); WA fgetss() 读 取 文 件 指针 处 行 并 值 赋 给 变量 
echo $myline; /显示 变量 


} 
fclose($myfile); /| 关闭 打开 的 文件 
?> 


</body> 
</html> 


把 以 上 代码 保存 为 “8-9.php”。 在 PHP 运行 环境 中 执行 以 上 代码 ， 将 会 出 现 如 图 8.3 所 示 的 执行 
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结果 。 
查看 源 文件 ， 只 有 以 下 内 容 : 


读 取 文件 内 容 读 取 文件 内 容 读 取 文件 内 容 


IE z 
读 取 文件 内 容 
8.3 通过 循环 使 用 fgetss0 读 取 文 件 内 容 
读 取 文件 内 容 
读 取 文件 内 容 


之 所 以 这 样 ， 是 因为 data.txt 文件 只 有 第 3、 第 6 和 第 8 行 含 有 文字 内 容 ， 其 他 行 均 为 htm 标记 。 
在 使 用 他 etssO 函 数 去 除 标记 后 ， 也 就 只 剩 第 3、 第 6 和 第 8 行 被 输出 了 。 


8.4.4 将 整个 文件 内 容 读 入 到 数组 变量 中 


通常 把 一 个 多 行 的 文件 的 全 部 内 容 读 入 到 数组 变量 中 会 使 用 file(string filename) 函 数 。 参 数 filename 
是 一 个 字符 型 变量 内 容 为 显示 内 容 的 文件 的 文件 名 。 函 数 返回 一 个 数组 ， 数 组 长 度 为 文件 行 数 ， 文 件 
的 一 行 对 应 数组 的 一 个 元 素 。 下 面 通过 一 个 实例 来 说 明 file(0) 函 数 的 使 用 方法 。 代 码 如 下 : 


<html> 

<head> 

<title>file() 函 数 使 用 实例 </title> 
</head> 


// 使 用 file 函数 将 整个 文件 内 容 读 入 到 数组 变量 中 

S$filename="data.txt"; /定义 变量 

$myfile=file($filename); IA file() 函 数 打开 文件 并 赋值 给 变量 
for($i=0;$i<count($myfile);$i++) IHE for 循环 


echo $myfile[$i]; // 显 示 数 组 变量 的 每 个 元 素 
} 


?> 
</body> 
</html> 


保存 以 上 代码 为 “8-10.php”。 在 PHP 运行 环境 中 执行 以 上 代码 ， 会 发 现 其 执行 结果 与 图 8.2 一 模 
一 样 。 两 个 实例 都 是 通过 循环 显示 出 了 文件 的 所 有 内 容 。 不 同 的 是 fgetc0 函 数 是 逐个 显示 各 个 字符 ， 
而 如 eO 则 是 把 文件 读 入 数组 ， 再 通过 显示 数组 元 素 显示 出 文件 内 容 的 。 
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8.5 删除 文件 


如 果 确 认 文件 已 经 没有 用 了 ， 并 且 以 后 也 不 会 再 用 到 ， 就 要 把 服务 器 上 的 文件 删除 以 节省 硬盘 空 
间 。 在 PHP 中 使 用 unlink() 函 数 来 执行 这 一 操作 。 

unlink(string filename) 函数 ,参数 filename 为 字符 变量 , 其 内 容 为 想 要 删除 文件 的 文件 名 。 执行 后 
删除 指定 文件 。 如 果 出 错 ， 则 返回 0 或 者 False。 当 然 ， 使 用 这 一 函数 之 前 需要 确认 文件 确实 不 再 有 用 ， 
执行 unlinkO 后 将 不 可 恢复 。 下 面 使 用 实例 来 介绍 这 一 函数 的 使 用 方法 。 代 码 如 下 : 

<html> 

<head> 


<title>unlink() 函 数 使 用 实例 <jtitle> 
</head> 


// 使 用 unlink 函数 删除 文件 

S$filename="data.txt"; /定义 变量 
unlink($filename); /用 unlink 函数 删除 文件 
za 

</body> 

</html> 


把 以 上 代码 保存 为 “8-11.php”。 在 PHP 运行 环境 中 执行 以 上 代码 ， 进 入 目录 将 会 发 现 data.txt X 
件 已 经 不 见 了 ， 因 为 它 已 经 被 删除 了 。 所 以 使 用 这 
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一 函数 前 ， 一 定 要 确认 文件 已 经 不 再 需要 ， 否 则 就 。。 eeoa 
再 也 无 法 恢复 To Te RUPE A me E directory) in 
使 用 此 函数 时 需要 注意 的 是 ， 删 除 的 文件 必须 m i ——.. 
是 存在 的 文件 。 如 果 文 件 名 并 不 存在 ， 就 会 出 现 如 — 
图 8.4 所 示 的 出 错 提示 。 图 8.4 unlink(O) 使 用 不 当 的 出 错 提示 
8.6 创建 目录 


有 时 需要 在 服务 器 上 创建 目录 。 如 创建 以 当天 日 期 为 名 字 的 目录 来 备份 数据 ， 或 者 创建 以 注册 用 
户 名 为 名 字 的 目录 来 存放 用 户 注册 信息 文件 等 。 在 PHP 中 使 用 mkdir() 函 数 来 完成 这 一 任务 。 

mkdir(string dirname:intmode) 函 数 ， 参 数 dimame 为 字符 变量 ， 内 容 为 想 要 创建 目录 的 名 称 ; 参数 
mode 为 整 型 变量 ， 表 示 创 建 模式 。 执 行 此 函数 将 在 指定 目录 下 创建 新 的 目录 。 下 面 通过 一 个 例子 来 说 
明 函 数 的 使 用 方法 。 代 码 如 下 : 

<html> 


<head> 
<title>mkdir() 函 数 使 用 实例 </title> 
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// 使 用 mkdir 函数 创建 目录 

$dimame="mydir"; /定义 变量 
mkdir($dirname,0700); /用 mkdir 来 创建 目录 
?> 

</body> 

</html> 


保存 以 上 代码 为 “8-12.php”， 并 在 PHP 运行 环境 中 执行 以 上 代码 ， 进 入 目录 会 发 现 多 出 了 一 个 
名 字 为 mydir 的 目录 ， 表 示 mkdir 创建 目录 这 名 被 顺利 执行 。 

使 用 此 函数 时 需要 注意 的 是 ， 创 建 的 目录 名 不 能 与 已 经 存在 的 目录 名 相同 ， 如 果 出 现 了 同样 的 目 
录 名 ， 就 会 出 现 如 图 8.5 所 示 的 出 错 提示 。 


ht //127 0 0_1/tert4_php — Microsoft Taternet Explorer 


XPO MEV SEW KUA IAV 帮助 四 La 
HED [E veto 7/127 0 0 Itete pin BBE 


D ~ 习 


Warning: MkDir failed (File exists) in c:\apache\htdocs\test4. php on line 4 


[BE TT i 


图 8.5 mkdir0) 使 用 不 当 的 出 错 提示 
8.7 删除 目录 


和 文件 一 样 ， 如 果 确 认 目录 已 经 没有 用 ， 并 且 以 后 也 不 会 再 用 到 ， 就 要 把 目录 删除 。 在 PHP 中 使 
用 rmdir0 函 数 来 执行 删除 目录 的 操作 。 

rmdir(string dirname) Kte, Z% dimame 为 字符 变量 ， 内 容 为 想 要 删除 目录 的 名 称 。 执 行 此 函数 把 
指定 目录 删除 。 

下 面 通过 一 个 例子 来 说 明 函 数 的 使 用 方法 。 代 码 如 下 : 


<html> 
<head> 
<title>rmdir() 函 数 使 用 实例 </title> 


</head> 


// 使 用 rmdir 函数 删除 目录 

$dimame="mydir"; /定义 变量 
rmdir($dimame); /用 rmdir 来 删除 目录 
> 

</body> 

</html> 


把 以 上 代码 保存 为 “8-13.php”。 在 PHP 运行 环境 中 执行 以 上 代码 ， 进 入 目录 将 会 发 现 名 为 mydir 
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的 目录 已 经 被 删除 ， 表 示 rmdir 这 名 顺利 被 执行 。 
在 使 用 这 个 函数 时 有 两 个 注意 事项 : 
口 ”目录 必须 为 室 ， 如 果 非 空 就 会 出 现 如 图 8.6 所 示 的 出 错 提示 。 
口 ”要 删除 的 目录 必须 存在 ， 如 果 删 除 不 存在 的 目录 ， 就 会 出 现 如 图 8.7 所 示 的 出 错 提示 。 


全 http:/1127.0.0.1ftestt-ah — Mi pzp] 
ZAD REO SEV HRW IAV Ba |% 


| i ito: /i200 1/testt-php — mai 
HO REO ZEV KRW IAV FHU |& 
Warning: RuDir failed (Directory not empty) in Warning: RuDir failed (No such file or directory) in 
c:\apache\htdocs\test4. php on lins 4 c:\apache\htdocs\test4. php on lins 4 
到 zi 
[Ea CO Er 加 aa LA KAA KAA AI Oi yA 
图 8.6 rmdir(O 使 用 不 当 的 出 错 提示 A) 图 8.7 rmdir() 使 用 不 当 的 出 错 提示 (2) 


8.8 浏览 目录 下 的 文件 


在 进行 PHP 编程 的 时 候 ， 需 要 对 服务 器 某 个 目录 下 面 的 文件 进行 浏览 ， 这 时 就 需要 用 到 opendir() 
函数 、readdir() 函 数 和 closedir() 函 数 ， 详 见 表 8.3。 


表 8.3 查看 目录 下 的 文件 相关 函数 


参数 及 返回 值 
参数 path 为 目录 的 路 径 及 目录 名 。 函 数 返回 值 为 可 供 其 他 目录 函数 使 用 的 int 
型 句柄 
参数 dir_handle 为 已 经 用 opendir0 函 数 打开 的 可 操作 目录 句柄 。 函 数 返 
录 中 的 文件 名 称 
参数 dir_handle 为 已 经 用 opendir() 函 数 打开 的 可 操作 目录 人 句柄。 函数 无 返回 
值 ， 运 行 后 ， 将 关闭 打开 指向 dir handle 的 目录 


函 数 名 作 用 
opendir(string path) 打开 指定 目录 


E 
m 


readdir(int dir_handle) | 读 取 指 定 目录 


closedir(int dir handle) | 关闭 指定 目录 


下 面 用 一 个 实例 来 说 明 这 3 个 函数 的 使 用 方法 。 注 意 ， 在 使 用 该 例子 前 请 确保 同一 目录 下 有 data 
文件 夹 。 代 码 如 下 : 


<html> 

<head> 

<title> 浏 览 目录 中 的 文件 </title> 
</head> 

<body> 

<table border="1"> 

<tr> 

<td> 文 件 名 </td> 
<td> 文 件 大 小 </td> 

<td> 文 件 类 型 </td> 
<td> 修 改 时 间 </td> 

</tr> 

<? 

$dimame="data"; /定义 变量 
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$dir handle=opendir($dirname); NA opendir 打开 目录 
while($file=readdir($dir_handle)) 1/ 循环 读 取 目录 里 的 内 容 
{ 
echo "<tr>"; 
echo "<td>".$file."</td>"; // 显 示 文件 名 
echo "<td>".filesize( $file)."</td>"; /显示 文件 大 小 
echo "<td>".filetype($file)."</td>"; // 显 示 文 件 类 型 
echo "<td>".date("Y 年 n 月 t 日 ",filemtime(S$file))."</td>"; // 格 式 化 显示 文件 修改 时 间 
echo "</tr>"; 
} 
closedir($dir_handle) /关闭 文件 操作 句柄 
> 
</table> 
</body> 
</html> 


把 以 上 内 容 保存 为 一 个 名 称 为 “8-14.php” 文 件 ， 在 PHP 执行 环境 下 运行 这 个 文件 ， 执 行 结果 如 
图 8.8 所 示 。 


RFO WD AFO WAW IRD FWO | æ 


ika aaa 多 件 关 型 你 改 时 间 | 
3 dir 2006 征 8 月 5I 日 | 


f 3 dir 200e 年 7 月 531 日 | 
index.html 1577 [file  [2002F2A288 | 
[eadme. txt 2221 file [2002 年 2 月 28 日 | 
fdata. txt 120 file [2006 年 8 月 51 日 | 
上 .jpg 44087 [file |2005 年 11 月 30 日 
区 jpg 53769 [file [12005 芋 11 月 50 日 | 
jpg 33581 [fil 005 年 11 月 30 日 | 
|a. ivg 49033 [file (2005114308 | 
[5. jpg 41998 [file [2005115300 | 
[test4. php. bak 514 file |2006 年 8 月 51 日 | 
ltesid.php 514 file kaa | 

z 

Wa UA Sru H 


图 8.8 浏览 目录 中 的 文件 


当然 ， 显 示 细 节 会 因为 文件 夹 里 内 容 的 不 同 而 有 所 不 同 。 通 过 上 例 可 见 ， 在 PHP 中 浏览 文件 夹 中 
的 内 容 也 并 不 是 一 件 多 么 复杂 的 事情 。 


8.9 关于 文件 上 传 


文件 的 上 传 也 是 Web 应 用 程序 文件 操作 中 一 个 很 重要 的 组 成 部 分 。 因 为 大 部 分 文件 存在 于 用 户 客 
户 端 的 机 器 上 ， 如 果 要 想 让 其 他 用 户 访问 则 必须 要 把 它 上 传 到 服务 器 。 如 图 片 网 站 上 传 图 片 、 软 件 下 
载 站 需要 上 传 软件 、 音 乐 站 点 需要 上 传 MP3 音乐 文件 等 。PHP 也 提供 了 对 文件 上 传 的 支持 。 本 节 就 为 
读者 介绍 PHP 中 关于 文件 上 传 的 操作 。 

PHP 是 通过 Web 表单 中 的 FILE 组 件 来 实现 文件 上 传 的 。 关于 与 浏览 用 户 互动 的 Web 表单 将 在 本 
书 第 15 章 详细 介绍 ， 本 节 只 是 使 用 其 中 的 form 表单 来 实现 文件 上 传 的 目的 。 
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PHP 的 文件 上 传 主要 是 利用 form 表单 提交 一 个 FILE 对 象 给 服务 器 。 其 中 FILE 对 象 必须 包含 
Multipart/form-data 的 entype 属性 。 同 时 考虑 到 大 文件 上 传 容易 造成 网 络 超时 的 情况 ， 所 以 可 以 用 
set_time_limit($TimeLimit) 来 加 大 超时 限制 时 间 。 

表单 提交 后 ，PHP 将 检测 上 载 的 文件 。 文 件 存放 在 服务 器 上 的 一 个 临时 目录 中 。 同 时 生成 一 个 与 
文件 域 (上 传 的 文件 ) 同名 的 几 个 变量 ， 如 _name 代表 文件 名 称 ，_size 代表 文件 大 小 的 字 节 数 ，_type 
为 文件 的 类 型 。 由 于 临时 目录 会 被 删除 ， 所 以 必须 利用 copy() 函 数 将 文件 复制 到 目标 路 径 下 。 

下 面 给 出 文件 上 传 的 前 台 代 码 〈 因 为 前 台 只 有 fom 表单 ， 并 不 涉及 PHP 操作 ， 所 以 里 面 内 容 并 
没有 PHP 代码 ) 。 如 下 : 

<html> 

<head> 

<title> 文 件 上 传 的 前 台 页 面 </title> 

</head> 

<body> 

<form ENCTYPE="multipart/form-data" ACTION="8-16.php" METHOD="POST"> 

<input name="upfile" type="file"> 

<p> 

<input type=submit value=" 确 认 提交 "> 

<input type=reset value=" 重 新 选择 "> 

</body> 

</html> 


把 以 上 代码 保存 为 “8-15.php ”。 先 来 解释 一 下 ， 以 上 代码 中 的 fom 表单 有 一 个 属性 是 
action="8-16.php"。 因 为 这 里 要 使 用 8-16.php 来 处 理 表单 的 提交 ， 所 以 要 把 form 表单 的 action 属性 指 
向 该 文件 。 

下 面 就 来 编写 后 台 处 理 程序 8-16.php 的 内 容 。 代 码 如 下 : 


<html> 
<head> 
<title> 文 件 上 传 后 台 处 理 页 面 </title> 
</head> 
<body> 
<? 
if($upfile=="none") // 没 有 选 定 文件 的 处 理 
{ 
echo "没有 选择 文件 "; // 显 示 提示 信息 
echo "<p>"; 
echo "点 <a href=\'8-15.php\> 这 里 </a> 返 回 "; // 给 出 返回 链接 
} 
else // 选 定 文件 
{ 
S$filepath="images/"; // 定 义 路 径 
$filename-$filepath.$upfile name; // 新 的 路 径 及 文件 名 
echo $upfile name; /显示 文件 名 
echo "<p>"; 
echo $upfile_size; /显示 文件 大 小 


echo "<p>"; 
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echo $upfile type; // 显 示 文件 类 型 
if(copy($upfile,$filename)) // 复 制 文件 的 目标 路 径 
{ 
unlink($upfile); // 删 除 原 有 文件 
echo "<p>"; 
echo "指定 文件 已 经 成 功 上 传 ! "; 
echo "<p>"; 
echo "点 <a href=\"8-15.php\"> 这 里 </a> 返 回 "; // 给 出 返回 链接 
} 
else 
echo "XH EE RKU"; 
} 
} 
?> 
</body> 
</html> 


保存 以 上 代码 为 “8-16.php” 文 件 。 在 PHP 执行 环境 中 运行 8-15.php 文件 ， 其 执行 结果 将 会 如 
图 8.9 所 示 。 然 后 ， 先 不 选择 任何 文件 ， 而 是 直接 单 击 “ 确 认 提 交 ” 按 钮 ， 提 交 表 单 ， 将 会 出 现 如 


图 8.10 所 示 的 执行 结果 。 
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图 8.9 文件 上 传 前 台 页 面 执行 结果 
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图 8.10 不 选择 任何 文件 时 的 后 台 处 理 结果 


单 击 图 8.10 中 的 “这 里 ”链接 ， 返 回 8-15.php。 这 时 选择 一 个 文件 ， 如 “1.jpg” 文 件 ， 然 后 单 击 


“确认 提交 ”按钮 (在 执行 这 一 步 之 前 ,请 确认 8 
将 会 返回 如 图 8.11 所 示 的 结果 。 
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8.11 ”正确 选择 文件 上 传 的 执行 结果 


从 如 图 8.11 所 示 的 结果 可 以 看 到 ， 程 序 ] 


E 确 执行 了 文件 上 传 命令 。 打 开 8-16.php 同一 目录 下 的 


images 文件 夹 ， 发 现 里 面 多 了 一 个 名 为 1.jpg 的 图 片 文件 ， 说 明 整 个 上 传 过 程 顺利 完成 。 
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8.10 文件 操作 综合 实例 : 在 线 相 册 


本 节 将 综合 本 章 所 学 习 的 知识 ， 来 建立 一 个 简单 的 基于 文件 及 文件 上 传 的 在 线 相册 系统 。 在 线 相 
册 拥 有 图 片 文件 上 传 、 图 片 浏览 和 图 片 删除 等 功能 。 通 过 本 节 的 学 习 ， 将 会 把 本 章 所 学 的 知识 串联 起 
来 ， 使 读者 进一步 熟悉 PHP 中 关于 文件 的 操作 。 


8.10.1 系统 功能 

整个 相册 管理 系统 要 实现 的 功能 有 图 片 文件 的 上 传 操作 ;图 片 文件 的 浏览 操作 和 图 片 文件 的 删除 
操作 等 。 下 面 分 几 小 节 来 解释 创建 构成 本 系统 的 几 个 重要 文件 。 这 里 先 列 出 代码 ， 然 后 再 对 每 一 个 文 
件 进行 解释 。 
8.10.2 ”相册 系统 首页 面 

8-17.php 为 该 系统 的 第 一 个 显示 页 面 ， 它 将 读 取 存 放 数据 的 文本 文件 的 内 容 ， 从 而 显示 出 相应 的 


图 片 。 并 且 其 中 还 使 用 了 分 页 显示 ， 如 果 上 传 的 总 图 片 数 多 于 8 幅 ， 则 会 显示 下 一 页 的 链接 。 然 后 ， 
判断 所 在 的 页 ， 并 显示 出 相应 的 内 容 。 代 码 如 下 : 


<html> 

<head> 

<title> 简 易 相册 系统 首页 </title> 
</head> 

<body> 

<center> 

<h1> 简 易 相册 系统 首页 </h1> 
<p> 

<a href="8-18.php"> 上 传 图 片 </a><p> 
<? 

if(!$_GET["page"]) 

$page=1; 

else 

$page=$_GET["page"]; 
$filename-"data.dat"; 
$myfile=file($filename); 
$z=$myfile[0]; 

if($z=="") 

echo "目前 记录 条 数 为 : 0"; 


else 


$temp=explode("||",$myfile[0]); 
echo "共有 ".$temp[0]." 条 内 容 "; 
echo "&nbsp;&nbsp;&nbsp;&nbsp;"; 


/如果 没 有 参数 page 
// 则 显示 第 一 页 内 容 


// 如 果 带 有 参数 page， 则 显示 相应 页 内 容 
/指定 记录 数据 文件 名 

/使 用 fille() 函 数 把 文件 所 有 信息 读 入 一 个 数组 
// 把 数组 第 一 条 内 容 赋值 给 变量 

// 和 如 果 文件 为 空 ， 即 没有 任何 图 片上 传 
/显示 没有 记录 的 信息 

// 和 如 果 有 图 片上 传 


// 读 出 数组 第 一 条 记录 到 数组 
// 读 出 该 数组 第 一 个 元 素 〈 代 表 记 录 总 条 数 ) 
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$p_count=ceil($temp[0]/8); 
echo "分 ".$p_count." 页 显示 "; 
echo "&nbsp;&nbsp;&nbsp;&nbsp;"; 
echo "当前 显示 第 ".$page." 页 "; 
echo "<table border="1'>"; 
if($page!=ceil($temp[0]/8)) 
$current_size=8; 
else 
$current_size=$temp[0]%8; 
if($current_size==0) $current_size=8; 
for($i=0;$i<ceil($current_size/4);$i++) 
{ 

echo "<tr>"; 

for($j=0;$j<4;$j++) 

{ 


echo "<td>"; 


/计算 总 页 数 为 记录 总 条 数 除 以 每 页 显示 条 数 
/输入 总 页 数 


/当前 页 


/如 果 当 前 页 不 是 最 后 一 页 

// 当 前 页 最 多 可 显示 8 条 记录 

// 和 如果 当前 页 是 最 后 一 页 

// 当 前 页 显示 的 条 数 为 总 条 数 除 以 8 的 余数 
// 如 果 正 好 是 8 的 倍数 则 显示 8 条 内 容 
/通过 循环 输出 行 ， 每 行 四 列 


/通过 循环 输出 单元 格 ， 共 4 个 


$temp=explode("||",$myfile[$i*4+$j+($page-1)*8]);// 把 相应 的 记录 按 “||” 分 割 到 数组 


if(($i*4+$j+($page-1)*8)<$z) 


// 和 如果 当前 数 小 于 总 数 显示 图 片 


{ 
$imgfile="images\".$temp[1]; /显示 图 片 为 数组 的 第 2 个 元 素 
$flag=getimagesize($imgfile); /获得 图 片 的 大 小 以 加 以 大 小 处 理 
echo "<a href=8-20.php?id=".$temp[0]."><img src=imagesN".$temp[1]; 
if($flag[0]>180l|$flag[1]>100) // 如 果 图 片 太 大 
echo " width=180 height=".$flag[1]*180/$flag[0]; 
echo " border=\"0\"></a>"; /把 图 片 按 比例 缩放 显示 
} 
else 1/ 如果 当 前 数 比 总 记录 数 大 
echo "暂时 没有 图 片 "; /输出 没有 图 片 的 信息 
echo "</td>"; /| 结束 该 单元 格 
echo "</tr>"; /| 结束 行 
echo "</table>"; /| 结束 表格 
echo "<p>"; 
/以 下 内 容 为 分 页 显示 链接 
$prev_page=$page-1; /前 一 页 
$next_page=$page+1; /下 一 页 
if ($page<=1) /| 如果 当前 页 小 于 等 于 1 
echo "第 一 页 |"; 
} 
else /如 果 当 前 页 大 于 1 
{ 


echo "<a href='$PATH_INFO?page=1> 第 一 页 </a> | "; 


} 
if ($prev_page<1) 


echo "上 一 页 |"; 


/如果 前 一 页 小 于 1 
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2 // 如 果 前 一 页 大 于 等 于 1 
echo "<a href='$PATH_INFO?page=$prev_page'> 上 一 页 </a> | "; 
($next_page>$p_count) /| 如 果 下 一 页 大 于 总 页 数 
echo "下 一 页 | "; 

zA /如 果 下 一 页 小 于 等 于 总 页 数 
echo "<a href='$PATH_INFO?page=$next_page'> 下 一 页 </a> |" 

A ($page>-$p. count) /如 果 当 前 页 大 于 等 于 总 页 数 
echo "最 后 一 页 </p>\n"; 

PA /如 果 当 前 页 小 于 总 页 数 
echo "<a href='$PATH_INFO?page=$p_count> 最 后 一 页 </a></p>\n"; 

和 

</center> 

</body> 

</html> 


保存 以 为 代码 为 “8-17.php”， 以 备 后 用 。 
8.10.3 ”相册 系统 上 传 前 台 页 面 


接 下 来 制作 上 传 图 片 的 前 台 页 面 8-18.php。 这 一 页 面 中 没有 太 多 的 PHP 技术 ,不 过 利用 了 JavaScript 
技术 ， 来 实现 对 内 容 是 否 为 空 的 判断 ， 以 及 预览 将 要 上 传 的 图 片 。 关 于 JavaScript 的 内 容 ， 这 里 不 进行 
介绍 ， 请 读者 参阅 相关 书籍 。 代 码 如 下 : 


<html> 

<head> 

<title> 相 册 管 理 系统 图 片上 传 页 面 </title> 
</head> 

<body> 

<script language="javascript"> 

function Juge(theForm) 


if (theForm.upfile.value == "" 


alert(" 请 先 选择 文件 ! "); 
theForm.upfile.focus(); 
retum (false); 
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if (theForm.content.value == "") 


{ 
alert(" 请 输入 图 片 说 明 ! "); 
theForm.content.focus(); 
retum (false); 
3 
if (theForm.content.value.length>60) 
{ 
alert(" 图 片 说明 内 容 太 多 了 ， 请 删除 一 点 再 发 ! "); 
theForm.content.focus(); 
retum (false); 
} 
} 
function viewmypic(img1,upfile) 
{ 
if (upfile.value) 
{ 
img1.src=upfile.value; 
img1.style.display=""; 
img1.border=1; 
} 
} 
</script> 
<center> 
<h1> 相 册 管 理 系 统 图 片上 传 页 面 </h1> 
<p> 


<a href="8-17.php"> 返 回首 页 </a> 
<table border="1"> 
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<form ENCTYPE="multipart/form-data" ACTION="8-19.php" METHOD="POST" onsubmit="retum Juge(this)"> 


<tr> 

<td> 选 择 图 片 : </td> 

<td><input name="upfile" type="file" onchange=viewmypic(img1,this.form.upfile)></td> 
</tr> 

<tr> 

<td> 输 入 说 明 : </td> 

<td><input name="content" type="text">(* 限 30 字 )</td> 

</tr> 

<tr> 

<td colspan="2"><center><input type=submit value=" 确 认 提交 "> 

<input type=reset value=" 重 新 选择 "></center></td> 

</tr> 

<tr> 

<td colspan="2"><center><img src="" id="img1" style="display:none;"></center></td> 
</tr> 

</table> 

</center> 

</body> 

</html> 
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把 以 上 代码 保存 为 “8-18.php”， 以 备 后 用 。 其 中 的 form 表单 的 enctype 属性 必须 为 


8.10.4 相册 系统 上 传 后 台 页 面 


multipart/form-data， 这 是 实现 文件 上 传 的 关键 。 另 外 ， 表 单 的 action 属性 指向 8-19.php， 这 就 是 处 理 上 
传 结果 的 页 面 。8.10.4 小 节 就 来 创建 这 个 页 面 。 


该 页 面 实现 的 功能 不 仅 要 把 文件 上 传 到 目标 文件 夹 ， 而 且 还 要 把 相关 信息 写 入 到 记录 文件 之 中 。 


所 以 这 里 用 到 较 多 的 PHP 文件 操作 的 内 容 。 代 码 如 下 : 


<html> 

<head> 

<html> 

<head> 

<title> 相 册 管 理 系统 后 台 处 理 页 面 </title> 


if($upfile=="none") 


echo "没有 选择 文件 "; 
echo "<p>"; 


echo "点 <a href=\"8-18.php\"> 这 里 </a> 返 回 "; 


f 


else 


S$filepath="images/"; 
S$filename=$filepath.$_FILES[upfile][name];; 
if(copy($upfile, $filename)) 
{ 
unlink($_FILES[upfile][tmp_name]); 
$dataname="data.dat"; 
$myfile=file($dataname); 
if(Smyfile|oj--"" 
{ 
$fp=fopen($dataname,"a+"); 


// 如 果 没 有 选择 相应 的 文件 
/| 输出 信息 


// 给 出 返回 链接 


// 定 义 上 传 的 路 径 
// 定 义 文件 名 
// 如 果 文 件 被 顺利 复制 


/删除 临时 文件 

/定义 记录 文件 名 

// 使 用 file() 把 记录 文件 按 行 读 入 数组 
// 如 果 记录 文件 为 空 


fwrite($fp,"1||".$_FILES[upfile][name]."]|".$_POST["content"]."]|".date(Y 4 m A d A)."\n"); 


fclose($fp); 
} 


else 


S$temp=explode("||",$myfile[0]); 
$temp[0]++; 
$fp=fopen($dataname,"r"); 


$line has-fread($fp,filesize("$dataname")); 


fclose($fp); 
$fp=fopen($dataname,"w"); 


/直接 写 入 行 号 为 1 的 内 容 
// 如 果 记录 文件 非 空 即 已 经 有 内 容 


/把 第 一 条 记录 按 “|| ”分割 到 数组 
/得 出 总 记录 数 并 自 增 1 
/以 只 读 方式 打开 文件 

INEM fread 读 出 文件 已 经 存在 的 内 容 
/关闭 文件 

/以 写 入 方式 打开 文件 


fwrite($fp, $temp[0]."||".$_FILES[upfile][name]."||".$_POST["content"]."||".date(Y 年 m A d A)."\n"); 
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// 写 入 新 的 内 容 
fwrite($fp,"$line has"); // 写 入 原来 已 经 存在 的 内 容 
fclose($fp); /关闭 文件 
$ 
echo "<p>"; 
echo "指定 文件 已 经 成 功 上 传 ! "; 
echo "<p>"; 
echo "点 <a href=\"8-17.php\"> 这 里 </a> 返 回 "; // 给 出 返回 链接 
} 
else 
echo "文件 上 传 失败 "; // 如 果 没有 复制 相应 文件 显示 失败 信息 
} 
} 
?> 
</body> 
</html> 


把 以 上 代码 保存 为 “8-19.php”， 以 备 后 用 。 现 在 文件 上 传 的 任务 完成 了 ，8.10.5 小 节 将 创建 显示 
图 片 文件 全 部 信息 页 面 。 


8.10.5 相册 系统 浏览 图 片 详细 信息 页 面 


通过 8.10.3，8.10.4 小 节 的 页 面 ， 文 件 上 传 任务 已 经 完成 了 。 不 过 还 不 够 完善 ， 因 为 现在 系统 还 只 
限于 上 传 图 片 。 如 何 浏览 图 片 文件 的 全 部 信息 呢 ? 这 一 小 节 来 创建 页 面 用 于 浏览 文件 的 详细 信息 。 其 
实 就 是 利用 explode0) 函 数 把 记录 内 容 分 割 到 数组 中 ， 再 分 别 显示 数组 各 个 元 素 。 具 体内 容 参看 以 下 
代码 : 


<html> 

<head> 

<title> 简 易 相册 系统 查看 图 片 </title> 
</head> 

<body> 

<center> 

<h1> 简 易 相册 系统 查看 图 片 页 </h1> 
<p> 

<? 


if(!$_GET["id") // 如 果 没 有 指定 1D 
f 


echo "没有 指定 ID"; // 输 出 相应 信息 
echo "<p>"; 
echo "点 <a href=\"8-17.php\"> 这 里 </a> 返 回 "; /给 出 返回 链接 
exit(); 

} 

else IRA ID 

{ 

?> 

<a href="8-17.php"> 返 回首 页 </a>&nbsp;&nbsp;&nbsp;&nbsp; 


sina 
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<a href="8-21.php?id=<? echo $id ?>"> 删 除 图 片 </a><p> 


<? 
$id=$_GET["id"]; 
$filename-"data.dat"; 
$myfile=file($filename); 
$z=$myfile[0]; 
if($z=="") 
echo "目前 记录 条 数 为 : 0"; 
else 


í 


S$temp=explode("||", $myfile[$z-$id]); 


echo "<table border='1'>"; 
echo "<tr>"; 

echo "<td>"; 

echo "文件 名 : ".$temp[1]; 
echo "</td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td>"; 


echo "<img src=\"images\\".$temp[1]."\">"; 


echo "</td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td>"; 

echo "图 片 简介 : ".$temp[2]; 
echo "</td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td>"; 

echo "上 传 日 期 : ".$temp[3]; 
echo "</td>"; 

echo "</tr>"; 

echo "</table>"; 


} 

?> 
</center> 
</body> 
</html> 


把 以 上 代码 保存 为 “8-20.php”， 以 备 后 


一 般 情况 下 ， 有 了 上 述 儿 个 文件 ， 


已 经 可 


务 器 上 删除 呢 ? 所 以 还 需要 一 个 页 面 
的 文件 。 


于 实现 


8.10.6 ”相册 系统 图 片 删除 页 面 


要 删除 文件 其 实 很 简单 ， 使 


// 把 参数 赋值 给 变量 

// 定 义 记录 文件 

/使 用 file() 函 数 把 文件 按 行 读 入 数组 
// 把 数组 第 一 个 变量 赋值 为 变量 

// 如 果 记 录 数 为 0 

// 显 示 相 应 内 容 

// 如 果 有 内 容 


WA explode() 函 数 按 “||” 把 相应 记录 分 割 


// 显 示 数 组 第 二 个 元 素 即 文件 名 


/显示 图 片 


/显示 图 片 第 三 个 元 素 即 图 片 简介 


// 显 示 图 片 第 四 个 元 素 即 上 传 日 期 


以 满足 基本 需要 了 。 但 是 ， 如 何 把 没有 价值 的 图 片 从 服 
图 片 的 删除 操作 。8.10.6 小 节 就 来 创建 实现 图 片 删除 操作 


unlink(O) 函 数 就 可 以 了 。 可 现在 问题 是 不 光 要 把 文件 删除 ， 而 且 还 要 


对 记录 文件 作 相应 的 修改 。 删 除 文件 前 的 内 容 保持 不 变 ， 删 除 后 的 每 条 记录 还 得 -1。 下 面 就 给 出 能 实 
现 该 功能 
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的 文件 。 具 体内 容 参看 以 下 代码 : 


<html> 

<head> 

<title> 相 册 管 理 系统 删除 图 片 处 理 页 面 </title> 
</head> 

<body> 


<? 


HAS 


else 


GET["id"]) 


echo "没有 指定 ID"; 
echo "<p>"; 


echo "点 <a href=\"8-17.php\"> 这 里 </a> 返 回 "; 


exit(); 


$id=$_GET["id"]; 
$filename="data.dat"; 
$myfile=file($filename); 
$z=$myfile[0]; 
if($z=="") 
echo "目前 记录 条 数 为 : 0"; 
else 
{ 
S$temp=explode("||", $myfile[$z-$id]); 
Sfilepath="images/"; 
$imgfile=$filepath.$temp[1]; 
unlink($imgfile); 
for($i=0;$i<($z-$id);$i++) 
{ 
$temp2=explode("||",$myfile[$i]); 
S$temp2[0]--; 


=133+ 


// 如 果 没 有 指定 1D 
// 显 示 相 应 信息 
// 给 出 返回 链接 


// 如 果 有 ID 


// 把 参数 ID 赋值 给 变量 

// 定 义 记录 文件 

// 使 用 file() 函 数 把 文件 按 行 读 入 到 数组 
// 数 组 第 一 个 元 素 赋值 给 变量 

// 如 果 第 一 行为 空 

// 输 出 没有 记录 

// 如 果 记 录 非 空 


IHEM explode 分 割 相应 记录 到 数组 
/定义 路 径 

// 获 得 文件 名 

/删除 文件 

/从 第 一 条 记录 读 到 和 欲 删除 的 记录 


IHEM explode 分 割 相 应 记录 到 数组 
// 记 录 号 实现 自 减 


$text2=$text2.$temp2[0]."||".$temp2[1]."||".$temp2[2]."||".$temp2[3]; 


} 
for($i=($z-$id+1):$i<$z;$i++) 
$text1=$text1.$myfile[$i]; 


} 

$fp=fopen($filename,"w"); 
fwrite($fp, $text2); 

fwrite($fp, $text1); 

fclose($fp); 

echo "指定 文件 已 经 删除 成 功 ! "; 


echo "<p>"; 


echo "点 <a href=\"8-17.php\"> 这 里 </a> 返 回 "; 


// 把 新 的 内 容 赋 值 到 变量 

// 新 欲 删 除 的 后 一 条 记录 到 最 后 一 条 记录 
// 内 容 保 持 不 变 

/以 写 入 方式 打开 文件 〈 文 件 同 时 被 清空 ) 
// 写 入 欲 删除 记录 之 前 自 减 后 的 所 有 记录 


// 写 入 欲 删除 记录 后 的 所 有 记录 
/关闭 文件 
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J 
</body> 
</html> 


把 以 上 代码 保存 为 “8-21.php”， 以 备 后 用 。 
到 这 里 ， 整 个 相册 管理 系统 就 基本 上 完成 了 。 既 能 实现 文件 上 传 、 浏 览 ， 又 可 以 实现 对 图 片 文件 
的 删除 操作 。 下 面 ， 来 看 一 看 该 系统 的 执行 结果 ， 更 直观 地 感受 一 下 编程 带 来 的 乐趣 。 


8.10.7 测试 相册 系统 


在 运行 此 系统 之 前 要 做 一 些 简单 的 准备 工作 。 第 1， 在 系统 同一 目录 下 建立 一 个 名 为 images 的 文 
ER: 第 2， 在 系统 同一 目录 下 建立 一 个 名 为 data.dat 的 文本 文件 。 读 者 可 以 先 建 一 个 文本 文件 ， 里 面 
什么 也 不 要 输入 。 然 后 把 扩展 名 改 为 dat 即 可 。 

(1) 运行 8-17.php。 第 1 次 运行 ， 执 行 结 果 如 图 8.12 所 示 。 由 于 此 时 还 没有 任何 图 片 被 上 传 ， 记 
录 文 件 里 的 记录 是 空 的 。 

(2) 单 击 “ 上 传 图 片 ”链接 ， 进 行 图 片 的 上 传 。 单 击 链接 后 ， 出 现 如 图 8.13 ited tan 


3 4 有 管理 系 纺 图 片上 传 页 面 ”icressft Intermel ER 


AN = 
XFO MBO EFV KRW IAV 


Do [3 


简易 相册 系统 首页 
Re a E 
ae BARA 门 O Ro) 
目前 记录 条 数 为 ，0 = 
第 一 页 | 上 一 页 | 下 一 页 | 景 后 一 页 


UA KAA KAA EX 


(mlml ml ml ml Er 
图 8.12 简易 相册 系统 首页 第 1 次 执行 结果 图 8.13 ”相册 管理 系统 图 片上 传 页 面 执行 结果 

(3) 单 击 “ 浏 览 ” 按 钮 ， 选 择 相应 的 图 片 。 页 面 最 下 方 出 现 相应 图 片 的 预览 效果 ， 如 图 8.14 所 示 。 

(4) 输入 相应 的 图 片 说 明 ， 此 处 输入 “用 户 图 像 第 1 幅 图 ”， 单 击 “确认 提交 ”按钮 ， 就 可 把 图 


片上 传 到 服务 器 上 了 o 
由 于 8-19.php 的 输出 结果 很 简单 ， 只 是 简单 的 提示 上 传 成 功 ， 然 后 给 出 一 个 返回 首页 的 链接 。 上 
传 了 一 幅 图 片 的 8-17.php 的 效果 如 图 8.15 所 示 。 
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返回 首页 LRA 
i \docunent \] ictur f es wA 
RMH: [Enorme Farrer AEE 共有 1 条 内 容 。 分 /页 显示 kiu 
| E [| 
Eee JA WA UA 
第 -页 | L-A | 下 -页 | 最 后 -页 
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图 8.14 ”相册 管理 系统 图 片上 传 页 面 图 片 预览 效果 图 8.15 ”上传 一 幅 图 片 后 的 简易 相册 系统 首页 执行 结果 
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打开 目录 下 的 images 文件 夹 , 查看 里 面 也 增加 了 一 个 图 片 文件 。 再 查看 相册 系统 目录 下 的 data.dat 
文件 ， 里 面 显示 如 下 信息 。 
1II1.gifl| 用 户 图 像 第 1 幅 图 ||2006 年 09 A 20 日 


这 是 图 片 的 详细 信息 ， 包 括 图 片 的 序号 、 文 件 名 、 图 片 说 明和 上 传 日 期 等 。 说 明 记录 文件 正确 记 
录 了 相关 内 容 。 此 时 可 以 直接 单 击 图 片 ， 以 查看 图 片 详细 信息 。 打 开 后 的 效果 如 图 8.16 所 示 。 

这 里 显示 出 了 已 经 上 传 图 片 的 详细 信息 。 单 击 “ 返 回首 页 ”链接 ， 以 继续 上 传 图 片 。 

现在 继续 上 传 图 片 ， 以 验证 系统 的 分 页 显示 功能 是 否 正常 运行 。 如 果 上 传 的 图 片 超过 了 8 幅 ， 
8-17.php 的 下 方 就 会 显示 出 到 另外 页 的 链接 ， 如 图 8.17 所 示 。 


ARRAMARN - Microsoft Internet Erpisren igxi 
IHO MEO FEV HRW IRAD PHU e 


E 简易 相册 系统 首页 
zho ao ZEV EN TAO RHO s 上 传 图 片 
简易 相册 系统 查看 图 片 页 CO MEIT ai 


La. 2 aie 


[EFB 200565059205 E 第 一 页 | 上 一 页 | 下 一 页 | 最 后 一 页 
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图 8.16 简易 相册 系统 查看 图 片 详细 信息 页 ”图 8.17 简易 相册 系统 首页 的 分 页 功能 起 了 作用 


可 以 看 出 ， 最 上 面 显示 的 内 容 是 “共有 9 条 内 容 ， 分 2 页 显示 ， 当 前 显示 第 1 页 ”， 而 最 下 方 则 显 
示 了 “下 一 页 ”及 “最 后 一 页 ”的 链接 。 单 击 “ 下 一 页 ”链接 ， 执 行 结果 如 图 8.18 所 示 。 

这 里 显示 的 是 第 2 页 的 内 容 ， 说 明 分 页 功能 正常 。 这 时 再 单 击 “ 上 一 页 ”链接 ， 就 回 到 了 第 一 页 。 
这 时 ， 打 开 data.dat 文件 ， 里 面 将 会 有 如 下 内 容 : 

9|l9.gifl| 用 户 图 像 第 9 幅 图 ||2006 年 09 月 20 A 

8||8.gifl| 用 户 图 像 第 8 幅 图 ||2006 年 09 月 20 A 

7|I7.gifl| 用 户 图 像 第 7 幅 图 ||2006 年 09 月 20 日 

6ll6.gifll 用 户 图 像 第 6 幅 图 ||2006 年 09 A 20 A 

5||5.gifl 用 户 图 像 第 5 幅 图 ||2006 年 09 月 20 A 

4||4.gifl| 用 户 图 像 第 4 幅 图 ||2006 年 09 月 20 日 

3||3.gifl 用 户 图 像 第 3 幅 图 ||2006 年 09 月 20 A 

2|l2.gifll 用 户 图 像 第 2 幅 图 ||2006 年 09 A 20 A 

1I1.gifll 用 户 图 像 第 1 幅 图 ||2006 年 09 月 20 A 


记 下 这 些 内 容 ， 以 和 删除 图 片 的 内 容 作 比较 。 接 下 来 ， 来 验证 一 下 删除 用 户 上 传 图 片 功能 是 否 能 
正确 运行 。 操 作 步 骤 如 下 : 

(1) 单 击 如 图 8-16 所 示 的 图 中 第 1 行 第 4 个 图 形 ， 将 出 现 查 看 图 片 详细 信息 的 页 面 ， 如 图 8.19 
所 示 。 
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简易 相册 系统 首页 上 简易 相册 系统 查看 图 片 页 


共有 9 第 内容 


| 车 时 没有 图 片 EHRAM 


第 -页 | 上 一 页 | 下 一 页 | 景 后 一 页 


d 到 


EE Eii CE 4 D] [si Er 
图 8.18 简易 相册 系统 首页 的 分 页 功能 测试 图 8.19 删除 图 片 前 的 准备 


由 于 系统 没有 设 定 对 删除 进行 确认 的 功能 ， 所 以 一 旦 单 击 了 “删除 图 片 ” 链 接 ， 对 应 的 图 片 就 会 
被 删除 。 这 时 要 记得 已 经 上 传 了 9 幅 图 片 ， 分 两 页 显示 。 
(2) 单 击 “删除 图 片 ” ” 链接， 直接 执行 8-21.php。 执 行 完毕 会 提示 删除 成 功 ， 直 接 给 出 返回 首页 
的 链接 。 回 到 首页 ， 结 果 如 图 8.20 所 示 。 


号 辣 品 相 仍 厌 区 首页 ~ Microsoft Internet tele lolx) 
(IO MO FEO HRW IAD HRU e 
简易 相册 系统 首页 
上 传 图 片 


A MERR SNIT 下 第 1 页 


页 | 上 一 页 | 下 一 页 | 最 后 一 页 
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图 8.20 删除 了 一 幅 图 片 后 的 结果 
内 容 又 成 了 8 条， 并 且 那 一 幅 图 片 6.gif 已 经 不 见 了 。 这 时 打开 data.dat 文件 ， 里 面 内 容 如 下 : 


8|l9.gifll 用 户 图 像 第 9 幅 图 ||2006 年 09 A 20 A 
7ll8.gifl 用 户 图 像 第 8 幅 图 ||2006 年 09 月 20 A 
6ll7.gifll 用 户 图 像 第 7 E2006 4 09 A 20 A 
5||5.gifl 用 户 图 像 第 5 幅 图 ||2006 年 09 月 20 A 
4|l4.gifll 用 户 图 像 第 4 幅 图 ||2006 4 09 A 20 A 
3||3.gifl 用 户 图 像 第 3 幅 图 ||2006 年 09 月 20 A 
2|l2.gifll 用 户 图 像 第 2 幅 图 ||2006 4 09 月 20 A 
1I1.gifll 用 户 图 像 第 1 幅 图 ||2006 年 09 月 20 A 


与 前 面 的 data.dat 文件 内 容 相 比 较 ， 后 面 的 都 没 变 ， 前 面 的 序号 都 减少 了 1， 说 明正 常 完 成 了 删除 
图 片 的 操作 。 
至 此 ， 本 系统 测试 完毕 。 通 过 对 这 个 图 片 管 理 系统 的 调试 及 运行 可 以 看 到 ， 里 面包 含 了 大 量 的 文 
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件 操作 的 内 容 及 技巧 ， 对 本 章 所 学 的 内 容 是 一 个 很 好 的 检阅 。 读 者 一 定 要 认真 领会 其 中 的 内 容 ， 学 以 
致 用 ， 把 学 到 的 内 容 用 到 实际 的 工作 中 去 。 

但 是 ， 这 个 系统 还 有 一 些 需 要 完善 的 地 方 。 这 里 简要 介绍 一 下 ， 请 读者 自己 完成 。 

O 并 没有 对 用 户 上 传 内 容 作 判断 。 用 户 可 能 会 上 传 不 是 图 片 的 文件 ， 这 是 应 该 要 判断 的 。 解 决 
办 法 就 是 判断 文件 的 扩展 名 ， 或 者 使 用 getimagesize() 函 数 来 判断 图 片 类 型 ， 如 果 不 能 正确 返 
回 值 ， 就 证 明 不 是 图 片 ， 不 予以 上 传 。 

O 也 是 前 面 提 到 的 问题 , 没有 对 用 户 删 除 图 片 进 行 确认 。 如 果 用 户 误 单 击 了 链接 就 不 可 恢复 了 。 
解决 办 法 是 再 建 一 个 中 间 页 面 ， 或 者 在 8-21.php 中 带 上 一 个 参数 。 如 果 没 有 参数 则 只 是 给 出 
警告 信息 ， 其 中 有 指向 本 页 带 参数 的 链接 ， 如 果 用 户 仍然 单 击 了 链接 ， 那 么 就 执行 删除 文件 
操作 。 或 者 把 链接 做 如 下 简单 的 改动 ， 可 以 调用 JS 的 confirm 方法 来 达到 确认 的 目的 。 

以 下 是 未 改动 以 前 的 链接 : 

<a href="8-21.php?id=<? echo $id ?>"> 删 除 图 片 </a><p> 

改 为 如 下 样式 : 

<a onclick="c()" href="8-21.php?id=<? echo $id ?>"> 删 除 图 片 </a> 

在 链接 中 加 入 了 一 个 onclick 事件 ， 然 后 再 在 8-20 的 源 文件 中 加 入 以 下 JavaScript 代码 即 可 。 


<script language=javascript> 
function c() 


temp=confirm(" 确 定 要 删除 图 片 吗 ? "); 
if(temp==0) return else; 


</script> 

O “系统 存在 安全 隐患 。 因 为 只 要 是 浏览 该 页 面 的 用 户 均 可 以 上 传 图 片 ， 同 时 也 能 删除 图 片 。 解 
决 办 法 是 判断 用 户 来 源 ， 或 者 直接 给 上 传 及 删除 页 面 加 上 密码 ， 只 有 密码 正确 才能 执行 相关 
操作 。 这 样 就 提高 了 系统 的 安全 性 。 


8.11 本 章 小 结 


本 章 主要 介绍 了 PHP 编程 中 对 文件 的 操作 。 包 括 判断 文件 存在 、 获 取 文 件 属性 、 读 取 文 件 内 容 、 
增删 目录 、 浏 览 目 录 等 文件 操作 ， 同 时 还 讲解 了 文件 上 传 的 操作 ， 学 习 了 PHP 文件 类 库 函 数 的 使 用 与 
技巧 。 因 为 文件 的 操作 在 PHP 编程 中 有 着 广泛 的 应 用 , 所 以 熟练 掌握 这 些 函 数 的 使 用 及 文件 操作 技巧 ， 
对 PHP 的 Web 编程 将 起 到 事半功倍 的 效果 。 


第 
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用 PHP 获取 主机 信息 


使 用 phpinfo) R REMER 
RKRAPHRIER 

使 用 date) ARENE HAER 
获取 特定 日 期 的 信息 


aa aa 


在 使 用 PHP 进行 网 络 编程 的 时 候 ， 让 用 户 了 解 主 机 的 信息 及 使 用 者 的 情况 是 十 分 
有 必要 的 。 例 如 ， 著 取 主 机 的 操作 系统 类 型 、Apache 的 版 本 、PHP 解释 器 的 版 本 、 有 
无 MySQL 数据 库 支持 以 及 主机 的 日 期 、 时 间 等 内 容 。 这 一 章 来 介绍 PHP 中 常用 的 主 
机 函数 ， 包 括 phpinfo( 函 数 的 使 用 、 获 取 浏 览 器 相关 信息 、 使 用 日 期 时 间 函 数 获 取 相 
应 内 容 等 。 通 过 本 章 的 学 习 ， 读 者 对 于 如 何 获 得 主机 信息 将 有 一 个 深层 次 的 了 解 。 
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9.1 phpinfo() 的 使 用 


如 果 用 户 需要 全 面 了 解 服务 器 的 相关 信息 ， 使 用 phpinfo() 函 数 是 最 为 方便 的 。 该 函数 没有 参数 ， 
直接 返回 主机 的 全 部 信息 ， 使 用 非常 方便 ， 返 回 内 容 相当 广泛 。 正 因为 该 函数 包括 了 太 多 的 内 容 ， 其 
至 一 些 不 希望 被 用 户 发 现 的 内 容 ， 所 以 许多 服务 提供 商 往 往 禁 用 了 该 函数 。 

下 面 通过 一 个 实例 来 说 明 如 何 使 用 phpinfo0 函 数 及 它 的 返回 内 容 。 具 体内 容 参看 以 下 代码 : 

<html> 

<head> 


<title>phpinfo() 函 数 使 用 实例 </title> 
</head> 


phpinfo(); /显示 相关 信息 


以 上 代码 相当 简单 ， 起 实质 作用 的 只 有 “phpinfo0” 这 一 句 PHP 代码 。 保 存 以 上 代码 为 “9-1.php” 
然后 在 PHP 执行 环境 中 运行 以 上 代码 ， 其 执行 结果 如 图 9.1 所 示 。 


ET WAL v Aa Ba Wh) ba 


[Rogistored PHP Stroams_ |ohp, flo, http, ftp, compross.dib a 


SE 


ee 7 
图 9.1 phpinfo() 函 数 使 用 实例 执行 结果 
通过 图 9.1 可 见 ，phpinfo0) 函 数 返 回 的 内 容 相当 多 ， 几 乎 包括 了 所 有 与 PHP 主机 有 关 的 内 容 。 


9.2 浏览 器 相关 操作 


在 使 用 PHP 编写 Web 应 用 程序 时 , 获取 用 户 浏览 器 相关 信息 也 是 十 分 必要 的 。 如 使 用 者 所 使 用 的 
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浏览 器 信息 、 操 作 系 统 的 类 型 、 访 问 者 客户 机 的 IP 地 址 等 。 本 节 就 来 介绍 PHP 中 的 浏览 器 相关 操作 的 
内 容 。 


9.2.1 获取 访问 者 浏览 器 信息 


流行 的 浏览 器 有 很 多 种 ， 如 微软 公司 的 正 、 网 景 公司 的 Netscape, Opera ARKIN (Firefox) ~ 24 
游 等 。 不 同 的 浏览 器 支持 的 标准 不 同 ， 对 相同 的 HTML 也 有 不 同 的 解释 ， 所 以 判断 浏览 器 的 类 型 从 而 
为 用 户 提供 相应 的 网 页 是 很 有 必要 的 。 在 PHP 中 判断 浏览 器 的 类 型 也 是 一 件 很 简单 的 事情 ， 简 单 到 只 
使 用 系统 的 内 置 系统 变量 $_SERVER['HTTP_USER_AGENT"] 即 可 。 

在 第 3 章 介 绍 到 的 系统 变量 中 曾经 提 到 过 $_SERVER 是 一 个 特殊 的 PHP 保留 变量 , 它 包 含 了 主机 
提供 的 所 有 信息 ， 被 称 为 自动 全 局 变量 (或 “超级 全 局 变量 ”) 。 要 显示 该 变量 ， 只 需 简单 地 进行 如 
下 操作 。 

<? 


echo $_SERVER["HTTP_USER_AGENT"]; 
7> 


该 脚本 的 输出 可 能 是 Mozilla/4.0(compatible; MSIE 5.01; Windows NT5.0)。 
下 面 通过 一 个 实例 来 说 明 在 PHP 中 如 何 判断 用 户 浏 览 器 类 型 。 


<html> 

<head> 

<title> 判 断 浏览 器 类 型 使 用 实例 </title> 
</head> 


echo "您 的 浏览 器 类 型 为 :"; 
echo "<p>"; 
if(strstr($_SERVER["HTTP_USER_AGENT"], "MSIE")) /使 用 系统 变量 判断 用 户 浏览 器 类 型 


echo"lnternet Explorer"; 


</body> 
</html> 


保存 以 上 代码 为 “9-2.php”。 在 PHP 执行 环境 中 运行 以 上 代码 ， 其 执行 结果 如 图 9.2 所 示 。 
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Internet Explorer 
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9.2 判断 浏览 器 类 型 使 用 实例 执行 结果 
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9.2.2 ”获取 访问 者 的 IP 地 址 
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在 实际 应 用 中 ， 判 断 用 户 IP 也 是 很 有 必要 的 。 如 网 上 投票 程序 就 要 用 IP 来 判断 用 户 是 否 已 经 投 
过 票 、 限 制 IP 计数 器 用 IP 地 址 来 判断 当天 用 户 是 否 已 经 浏览 过 站 点 。 在 PHP 中 的 $_ SERVER 系统 变 
量 包含 了 主机 的 几乎 所 有 信息 ， 所 以 IP 地 址 自然 也 能 用 这 个 变量 获得 ， 其 获得 方法 是 使 用 


$_SERVER[REMOTE_ADDR]. 


下 面 通过 一 个 实例 来 说 明 如 何 使 用 


下 代码 : 


<html> 
<head> 


$_SERVER 系统 变量 来 获得 访问 者 的 IP 地 址 。 具体 内 容 参看 以 


<title> 获 得 访问 者 IP 地 址 使 用 实例 </title> 


</head> 

<body> 

<? 

echo "您 的 IP 地 址 为 : "; 

echo "<p>"; 

echo $_SERVER[REMOTE_ADDR]; 
?> 

</body> 

</html> 


保存 以 上 代码 为 “9-3.php”。 在 PHP 执行 环境 
中 运行 以 上 代码 ， 执 行 结果 如 图 9.3 所 示 。 您 和 TP 地址 为 ， 

从 图 9.3 中 可 以 发 现 正 确 显示 了 本 机 的 IP (由 于 127.0.0.1 
是 在 单机 上 进行 调试 程序 , 所 以 返回 的 


地 址 ) 。 
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只 是 单机 的 IP 


// 使 用 系统 变量 输出 用 户 IP 
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图 9.3 获得 访问 者 IP 地 址 使 用 实例 执行 结果 
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在 编程 中 了 解 系统 的 日 期 及 时 间 也 是 很 有 必要 的 。 如 在 制作 留言 短 时 ， 需 要 记录 用 户 的 留言 日 期 
及 时 间 ; 论坛 中 新 用 户 的 注册 日 期 及 时 间 等 。 在 PHP 中 要 获得 系统 的 日 期 及 时 间 是 很 容易 的 ， 这 一 节 


就 为 读者 分 别 作 介绍 。 


9.3.1 检查 日 期 的 合法 性 


用 户 的 输入 内 容 不 一 定 是 想 要 取得 的 内 容 。 如 让 用 户 输入 生日 ， 用 户 很 有 可 能 输入 “2 月 30 日 ” 


这 样 错误 的 日 期 ， 而 错误 的 日 期 入 库 ， 
日 期 是 否 正 确 是 很 有 必要 的 。 


将 会 给 统计 及 以 后 的 操作 带 来 很 多 不 便 。 所 以 判断 用 户 输入 的 


PHP 中 有 专门 用 来 检查 日 期 是 否 合法 的 函数 checkdate0。 如 果 日 期 合法 就 返回 True， 反 之 则 返回 
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False。 下 面 通过 一 个 实例 来 说 明 checkdate(O) 函 数 是 如 何 使 用 的 。 


<html> 

<head> 

<title> 检 查 日 期 合法 性 函数 使 用 实例 </title> 
</head> 


if(checkdate(12,30,2005)) // 如 果 检 查 日 期 合法 

echo "12,30,2005 是 正确 的 日 期 !"; 

else // 如 果 检查 日 期 不 合法 

echo "12,30,2005 不 是 正确 是 日 期 !"; 

echo "<p>"; 

if(checkdate(2,30,2005)) // 如 果 检 查 日 期 合法 

echo "2,30,2005 是 正确 的 日 期 ! "; 

else // 如 果 检 查 日 期 不 合法 

echo "2,30,2005 不 是 正确 是 日 期 !"; 

?> 

</body> 

</html> 

保存 以 上 代码 为 “9-4.php”， 在 PHP 执行 环境 中 运行 以 上 代码 ， 执 行 结果 将 会 如 图 9.4 所 示 。 
BEE) 
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12, 30, 2005 是 正确 的 日 期 | 
2005 2, 30 不 是 正确 的 日 期 | 


SE 
图 9.4 检查 日 期 合法 性 函数 使 用 实例 执行 结果 
学 习 过 英文 的 读者 都 知道 西方 的 日 期 表示 习惯 是 “月 、 日 、 年 ”。 所 以 从 图 9.4 结果 来 看 ， 12 月 
30 日 2005 年 是 一 个 正确 的 日 期 ， 而 2005 年 2 月 30 日 则 是 一 个 错误 的 日 期 。9-4.php 通过 checkdate() 
函数 判断 日 期 的 正确 性 ， 然 后 判断 返回 值 并 打印 相应 的 信息 。 


Ee 


9.3.2 ”格式 化 输出 当前 日 期 


这 一 小 节 来 介绍 PHP 中 如 何 获 得 当前 日 期 。 在 PHP 中 使 用 date0 函 数 加 上 不 同 的 参数 可 以 获得 不 
同 的 日 期 时 间 信息 。 具 体内 容 如 表 9.1 所 示 。 


表 9.1 date() 函 数 的 参数 意义 及 返回 值 


返 回 值 
d | 表示 显示 月 份 中 的 第 几 天 返回 有 前 导 零 的 2 位 数字 ， 从 01 到 31 
D | 表示 星期 中 的 第 几 天 ， 以 文本 形式 显示 “| 返回 3 个 字母 从 Mon 到 Sun 


表示 月 份 中 的 第 几 天 
表示 星期 几 


返回 没有 前 导 零 的 数字 ， 从 1 到 31 
返回 完整 的 文本 格式 从 Sunday 到 Saturday 


1(“L” 的 小 写字 和 母 ) 
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表示 意义 返 回 值 

表示 每 月 天 数 后 面 的 英文 后 级 aa 如 : st、nd、rd 或 者 th。 可 以 和 j 
w 表示 星期 中 的 第 几 天 返回 0 〈 星 期 天 ) 到 6《〈 星 期 六 ) 的 数字 
A 表示 年 份 中 的 第 几 天 返回 从 0 到 366 到 数字 

WA 返回 完整 的 文本 格式 ， 如 : January 或 者 March， 
y 表示 月 份 从 January 到 December 
m 以 数字 形式 表示 的 月 份 返回 有 前 导 零 的 2 位 数字 ， 从 01 到 12 
M 以 字母 形式 表示 的 月 份 返回 3 个 字母 缩写 表示 的 月 份 从 Jan 到 Dec 
n 以 数字 形式 表示 的 月 份 〈 与 m 不 同 ) 返回 无 前 导 零 的 位 数字 ， 从 1 到 12 
t 表示 一 月 的 天 数 返回 给 定 月 份 所 应 有 的 天 数 ， 从 28 到 31 
i KUUA wanu, FUNE EO 
kd 表示 年 份 返回 4 位 数字 完整 表示 的 年 份 ， 如 : 1999 或 2003 

表示 年 份 ( 与 Y 不 同 ) 返回 2 位 数字 表示 的 年 份 ， 如 : 99 或 03 
a 以 小 写字 母 表示 上 午 或 下 午 返回 值 为 am 或 pm 
A 以 大 写字 母 表示 上 午 或 下 午 返回 值 为 AM 或 PM 
g 表示 小 时 ，12 小 时 格式 返回 没有 前 导 零 的 表示 小 时 的 数字 ， 从 1 到 12 
G 表示 小 时 ，24 小 时 格式 返回 没有 前 导 零 的 表示 小 时 的 数字 ， 从 0 到 23 
h 表示 小 时 ，12 小 时 格式 与 g 不 同 ) 返回 有 前 导 零 的 表示 小 时 的 两 位 数字 ， 从 01 到 12 
H 表示 小 时 ，24 小 时 格式 (与 G 不 同 ) 返回 有 前 导 零 的 表示 小 时 的 两 位 数字 ， 从 00 到 23 
i 表示 分 钟 返回 有 前 导 零 的 分 钟 数 ， 从 00 到 59 
s 表示 秒 返回 有 前 导 零 的 秒 数 ， 从 00 到 59 

如 : EST，MDT 等 。 在 Windows 下 为 完整 文本 格 

T 表示 本 机 所 在 的 时 区 式 ， 如 “EasternStandardTime ”。 中 文 版 会 显示 


“中 国标 准时 间 ” 


下 面 用 一 个 实例 来 说 明 如 何 获得 系统 主机 的 日 期 及 时 间 ， 有 具体 内 容 参看 以 下 代码 。 


<html> 
<head> 
<title> 输 出 当前 日 期 函数 使 用 实例 </title> 


</head> 


echo "今天 的 日 期 是 :"; 
echo "<p>"; 

echo date(Y 年 n 月 d 日 ); 
echo "<p>"; 

echo "今天 是 星期 : "; 
echo date(w); 

echo "<p>"; 

echo "现在 的 时 间 是 : "; 


echo "<p>"; 


BAKAR 


// 输 出 星期 
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echo date(aG 点 1 分 s 秒 ); 


?> ET 
</body> 今天 的 日 期 是 ， i 
</html> 2006 年 9 月 07 日 
保存 以 上 代码 为 “9-5php”。 然 后 在 PHP 执行 环境 中 KEE 

运行 该 文件 ， 其 执行 结果 如 图 9.5 所 示 。 WAA 


PIH15 点 19 分 18 秒 


从 以 上 介绍 date0) 函 数 的 参数 及 图 9.5 所 示 的 执行 结果 
可 见 ， 使 用 date(0) 函 数 可 以 返回 主机 的 当前 日 期 。 


Wa KALII E 


9.5 输出 当前 日 期 函数 使 用 实例 执行 结果 


9.3.3 ”获得 时 间 及 日 期 信息 
通过 9.3.2 小 节 对 date0) 函 数 的 介绍 ， 知 道 在 PHP 中 获得 时 间 及 日 期 信息 是 一 件 很 容易 的 事情 ， 做 


的 使 用 格式 如 下 所 示 : 
array getdate([int timestamp]) 


函数 可 包含 参数 ， 参 数 为 一 个 表示 日 期 的 数字 ， 如 果 没 有 参数 则 返回 当前 日 期 的 信息 。 返 回 值 为 
一 个 数组 。 其 返回 的 数组 中 内 容 很 多 ， 返 回 数组 的 键 名 及 相应 值 的 情况 请 参见 表 9.2。 


表 9.2 getdate() 函 数 的 返回 值 数 组 的 键 名 单元 


a “名 返回 值 例子 
"seconds" 0 到 59 

"minutes" 0 到 59 

"hours" 0 到 23 

"mday" 1 到 31 

"wday" 0 (表示 星期 天 ) 到 6 (表示 星期 六 ) 
"mon" 1 到 12 

"year" 例如 ，1999 或 2003 

"yday" 一 年 中 第 几 天 的 数字 表示 0-365 

"weekday" 星期 几 的 完整 文本 表示 Sunday~Saturday 


"month" 月 份 的 完整 文本 表示 January~December 


下 面 继续 通过 实例 向 读者 介绍 PHP 编程 中 如 何 获得 时 间 及 日 期 信息 。 


<html> 

<head> 

<title> 获 得 时 间 及 日 期 信息 函数 使 用 实例 </title> 
</head> 

<body> 

<? 

$today=getdate(); 

echo "当前 年 份 为 :"; 
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echo $today[year]; 
echo "<p>"; 

echo "当前 月 份 为 :"; 
echo $today[month]; 
echo "<p>"; 

echo "当前 日 期 为 :"; 
echo $today[mday]; 
echo "<p>"; 

echo "今天 是 全 年 中 的 第 :"; 
echo $today[yday]." 天 "; 
echo "<p>"; 

echo "今天 是 星期 :"; 
echo $today[wday]; 


</body> 
</html> 


保存 以 上 代码 为 “9-6.php”。 在 PHP 执行 环境 中 
运行 该 文件 ， 执 行 结果 如 图 9.6 所 示 。 

除了 获取 当前 日 期 之 外 ， 也 可 以 在 getdate0) 函 数 中 
使 用 参数 ， 参 数 可 以 为 任意 合法 的 、 表 示 日 期 的 数字 ， 
函数 一 样 会 返回 这 一 日 期 的 信息 。 

到 这 里 PHP 中 的 日 期 时 间 函 数 基本 上 就 介绍 完了 。 
这 些 函 数 在 平时 编程 过 程 中 经 常 要 用 到 。 读 者 要 熟练 使 
用 日 期 时 间 函 数 ， 为 编写 复杂 的 Web 程序 打下 基础 。 ”图 9.6 获得 时 间 及 日 期 信息 函数 使 用 实例 执行 结果 


习 夏 冶 时 间 有 日 三 信 生 两 淮 全 用 安生 -wia MT. F] 
当前 年 份 为 ，2006 
当前 月 份 为 ，September 
当前 日 期 为 ，7 
今天 是 全 年 中 的 第 ，249 天 
今天 是 里 期 ，4 
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无 论 是 通过 系统 内 置 变量 获得 主机 信息 ， 还 是 通过 日 期 时 间 函 数 获得 日 期 时 间 信 息 ， 都 是 编写 大 
型 Web 应 用 程序 中 不 可 或 缺 的 内 容 。 在 大 型 应 用 程序 中 都 处 于 基础 的 位 置 。 通 过 本 章 的 学 习 ， 读 者 对 
如 何 获取 主机 相关 信息 ， 如 何 获 取 日 期 时 间 信 息 应 该 有 了 一 个 深刻 的 认识 。 


PHP 中 的 图 像 处 理 


PHP 页 的 图 信函 数 

使 用 GD 库 画 数 便 建 图 像 
使 用 GD 库 画 数 绘制 图 形 
GD 库 函 数 综合 应 用 突 例 


aa aa 


使 用 过 Internet 的 用 户 都 知道 ， 一 个 网 站 不 可 能 离开 图 片 。 各 种 各 样 的 图 片 ， 会 给 
死板 的 网 页 带 来 很 多 生机 。PHP 是 崇 入 式 语言 ， 所 以 PHP 页 中 除了 PHP 代码 之 外 都 是 
HTML 标记 ，PHP 文件 中 也 可 以 使 用 图 片 标记 。 但 PHP 又 不 仅仅 只 是 能 用 图 片 而 已 ， 
它 还 能 对 图 片 进 行 处 理 。 这 一 章 讲解 PHP 中 的 图 像 处 理 ， 内 容 包 括 PHP 中 的 简单 图 像 
函数 、GD 库 的 使 有 用、 图像 使 用 实战 、 使 用 GD 函数 创建 图 像 和 使 用 CD 库 函 数 绘制 几 
何 图 形 。 最 后 ， 本 章 还 讲解 了 几 个 实际 应 用 : 添加 图 片 文字 水 印 、 绘制 直方 统计 图 和 制 
作 图 像 的 缩 略图 。 
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10.1 图 像 函 数 


PHP 中 有 几 个 内 置 的 简单 的 图 像 函数 ， 还 有 功能 丰富 的 GD 库 函 数 。 简 单 的 图 像 函 数 可 以 用 来 读 
取 图 像 文件 的 长 宽 和 图 像 的 格式 。 而 GD 库 函 数 功 能 就 强大 得 多 ， 可 以 创建 图 像 、 已 有 图 像 的 缩 略 图 、 
在 图 片 文 件 上 写字 等 ， 这 一 节 就 分 别 为 读者 做 介绍 。 


10.1.1 访问 图 像 的 属性 


在 处 理 一 个 图 像 文件 之 前 ， 了 解 图 像 的 大 小 是 很 有 必要 的 。PHP 中 有 这 样 一 个 函数 用 来 返回 图 像 
的 长 、 宽 及 格式 。 这 个 函数 是 getimagesize()， 它 的 使 用 格式 如 下 所 示 : 

array getimagesize(string filename [,array &imageinfo]); 

函数 的 参数 为 指向 图 像 文件 路 径 及 文件 名 的 字符 串 ， 函 数 返 回 一 个 数组 。 其 中 数组 有 4 个 元 素 ， 
第 1 个 为 图 像 文 件 的 长 ， 第 2 个 为 图 像 文件 的 宽 ， 第 3 个 为 图 像 元 素 的 类 型 。 该 函数 支持 多 种 类 型 的 
图 像 ， 其 值 类 型 如 表 10.1 所 示 。 


表 10.1 getimagesize() 函 数 图 像 类 型 值 及 内 容 


函数 返回 值 指 代 的 图 像 类 型 
1 GIF 图 像 
2 JPG/JPGE 图 像 
3 PNG 图 像 
4 SWF (FLASH) 文件 
5 PSD (Photoshop) 文件 
6 BMP 图 像 
7. TIFF 
8 TIFE 
9 JPC 文 件 
10 JP2 文 件 
11 JPX 文 件 
12 JB2 文 件 
13 SWC 文 件 
14 IFF 文 件 
15 WBMP 文 件 
16 XBM 文 件 


这 些 标记 与 PHP 4.3.0 新 加 的 IMAGETYPE 常量 对 应 。 
第 4 个 参数 为 文本 字符 串 ， 内 容 为 “height="yyy",width="xxx"”， 可 直接 用 于 IMG 标记 。 
下 面 通过 一 个 实例 来 讲解 如 何 使 用 getimagesize() 函 数 来 访问 图 像 的 属性 。 具体 内 容 参 看 以 下 代码 : 
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<html> 

<head> 

<title> 访 问 图 像 属性 函数 使 用 实例 </title> 
</head> 


$image="1.jpg"; // 定 义 指向 图 像 文 件 的 字符 变量 
echo "<img src=".$image.">"; IARR 
$temp=getimagesize($image); /使 用 函数 并 把 返回 值 赋值 给 数组 
echo "<p>"; 
echo "该 图 像 的 长 为 :"; 
echo $temp[0]; // 调 用 图 像 的 长 
echo "<p>"; 
echo "该 图 像 的 宽 为 :"; 
echo $temp[1]; // 调 用 图 像 的 宽 
echo "<p>"; 
echo "该 图 像 的 格式 为 : "; 
switch ($temp[2]) // 通 过 判断 返回 图 像 的 格式 
case 1: // 如 果 图 像 为 GIF 
echo "GIF 图 像 "; 
break; 
case 2: // 如 果 图 像 为 JPG 
echo "JPG/JPGE 图 像 "; 
break; 
case 3: // 如 果 图 像 为 PNG 
echo "PNG 图 像 "; 
break; 
default: // 除 以 上 3 种 外 的 其 他 情况 
echo "未 知 图 像 格式 "; 
break; 二 
} zeo MD HEV HRW IAD WBW P 
?> 
</body> 
</html> 


保存 以 上 代码 为 “10-1.php”。 然 后 ， 在 PHP 执行 环 
境 中 运行 该 文件 (注意 在 执行 该 文件 以 前 ， 先 把 1jpg 放 


在 10-1.php 的 同一 个 目录 下 ), 其 执行 结果 如 图 10.1 所 示 。 BARNEH: 11 
通过 实例 发 现 ，getimagesize0) 函 数 能 返回 图 像 的 长 与 in 174 l 

宽 及 图 像 类 型 。 这 个 函数 对 于 网 页 中 图 像 的 插入 是 十 分 有 该 加 你 的 将 式 为 ，JPC/JPCE 图 像 ji 

用 的 。 PE COOS me F 


图 10.1 访问 图 像 属 性 函数 使 用 实例 执行 结果 
10.1.2 使 用 GD 库 函 数 


PHP 的 GD 库 函 数 是 专门 用 来 处 理 图 像 、 画 图 的 库 函 数 。 这 一 节 为 读者 介绍 PHP 中 常见 GD ER 
数 的 使 用 。 在 使 用 GD 库 之 前 要 先 让 PHP 解释 器 能 加 载 GD 库 函 数 。 方 法 就 是 修改 php.ini 文件 。 打 开 
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php.ini 文件 找到 这 一 行 : 

;extension=php_gd.dll 

把 前 面 的 “;” 去 掉 ， 然 后 ， 保 存 php.ini 文件 即 可 。 这 样 在 启动 PHP 解释 器 时 就 会 加 载 GD 库 函数 。 

在 前 面 儿童 中 已 经 向 读者 展示 过 GD 库 的 强大 功能 。 如 第 6 章 的 例子 6-7.php， 和 第 7 章 的 例子 
7-4.php。 当 时 第 6 章 的 重点 是 介绍 如 何 使 用 非 系统 库 函 数 ， 而 第 7 章 主 要 是 讲解 三 角 函 数 。 下 面 对 这 
两 个 例子 作 详 细 的 说 明 。 


先 来 回顾 第 6 章 的 例子 6-7.php: 


<? 
Header("Content-type: image/png"); 


// 输 出 一 个 PNG 图 片 文件 


$im=imagecreate(440,100); // 初 始 化 图 形 区 域 
$black=imagecolorallocate($im, 0,0,0); /定义 黑色 
$white=imagecolorallocate($im, 255,255,255); /定义 自 色 
$yellow=imagecolorallocate($im,255,255,0); /定义 黄色 
$blue=imagecolorallocate($im,0,0,255); /定义 蓝 色 
$red=imagecolorallocate($im,255,0,0); /定义 红色 
$zi=imagevolorallocate($im,255,0,255); /定义 紫色 
$color=$blue; // 定 义 $color 变量 为 蓝 色 
$font-"wingdings.ttf"; /定义 字体 文件 
imagefilledrectangle($im, 5, 5, 435, 95, $color); UA —NERK 
imagestring($im,5,7,10,"1:send",$white); /用 和 白色 写字 符 
for($i=0;$i<5;$i++) // 用 循环 画 字符 


imagettftext($im,40,0,90+$i*50,57,$yellow, $font,"Z"); // 画 出 字符 用 黄色 及 字体 


} 
imagestring($im,5,270,60,"to:YOU As a gift",$white); 


// 用 白色 写字 符 


imagestring($im,5,305,80,date(Y).".".date(m).".".date(d),$white); 。 // 写 出 当前 日 期 


Imagepng($im); /创建 图 形 
Imagedestroy($im); /| 关闭 图 形 
?> 


该 例子 使 用 了 GD 库 中 的 创建 图 像 函数 、 画 矩形 函数 、 在 图 像 上 写字 符 函 数 等 几 个 函数 。 执 行 结 


果 详 见 第 6 章 的 图 6.7。 


下 面 再 来 回顾 一 下 第 7 章 的 例子 7-4.php: 


<? 


Header("Content-type: image/png"); // 输 出 文件 头 为 PNG 图 片 
$im = imagecreate(400,400); // 使 用 GD 库 函 数 创建 区 域 
$black = imagecolorallocate($im, 0,0,0); /使 用 GD 库 函 数 定义 黑色 
$white = imagecolorallocate($im, 255,255,255); /使 用 GD 库 函 数 定义 白色 
$yellow = imagecolorallocate($im,255,255,0); /使 用 GD 库 函 数 定义 黄色 
$blue = imagecolorallocate($im,0,0,255); /使 用 GD 库 函 数 定义 蓝 色 
$red = imagecolorallocate($im,255,0,0); /使 用 GD 库 函 数 定义 红色 
imagefilledrectangle($im, 5, 5, 395, 395, $yellow); // 使 用 GD 库 函 数 画 矩形 
for($i=1;$i<360;$i++) // 通 过 循环 画 点 


$temp=150*sin(2*(pi(/180)*$i); 


// 通 过 三 角 函 数 计算 值 


$x=$temp*cos((pi()/180)*$i)+200; 


$y=S$temp*sin((pi()/180)*$i)+200; 
imagesetpixel ($im,$x,$y,$red); 
$temp=150*cos(2*(pi()/180)*$i); 


$x=$temp*cos((pi()/180)*$i)+200; 


$y=$temp*sin((pi()/180)*$i)+200; 
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// 通 过 三 角 函 数 计 算 点 的 横 坐标 

// 通 过 三 角 函 数 计 算 点 的 纵 坐 标 

// 通 过 GD FAREA 

// 通 过 三 角 函 数 计 算 第 2 个 值 

// 通 过 三 角 函 数 计算 点 的 横 坐标 

// 通 过 三 角 函 数 计 算 点 的 纵 坐 标 


imagesetpixel ($im,$x,$y,$blue); // 通 过 GD FAREA 
} 
Imagepng($im); /输出 PNG MK 
Imagedestroy($im); 1/ 清空 图 片 
?> 


该 例 除 了 使 用 创建 图 像 函数 之 外 ， 主 要 还 使 用 了 GD 库 函数 中 的 画 点 函数 。 该 函数 的 作用 是 在 固 
定 的 位 置 画 一 个 点 。 


表 10.2 常见 GD 库 函 数 意义 
取得 当前 安装 的 GD 库 的 信息 


取得 图 像 大 小 
取得 图 像 类 型 的 文件 后 级 
取得 getimagesize，exif read data 


exif thumbnail，exif imagetype ”| 所 返回 的 图 像 类 型 的 MIME 类 型 


image2wbm 以 WBMP 格 式 将 图 像 输出 到 浏览 器 或 文件 
imagealphablendin; 设 定 图 像 的 混 色 模式 

imageantialias 是 否 使 用 抗 锯 齿 〈antialias) 功能 
imagearc 画 椭圆 弧 

imagechar 水 平地 画 一 个 字符 

imagecharu 垂直 地 画 一 个 字符 

Tasnia 为 一 幅 图 像 分 配 颜 色 
imagecolorallocatealpha 为 一 幅 图 像 分 配 颜 色 +alpha 

imagecolorat 取得 某 像素 的 颜色 索引 值 


取得 与 指定 的 颜色 最 接近 的 颜色 的 索引 值 
取得 与 指定 的 颜色 加 透明 度 最 接近 的 颜色 
取得 与 给 定 颜色 最 接近 的 色 度 的 黑白 色 的 索引 
取消 图 像 颜色 的 分 配 

imagecolorexact 取得 指定 颜色 的 索引 值 


imagecolorexactalpha 取得 指定 的 颜色 加 透明 度 的 索引 值 


imagecolormatch 使 一 个 图 像 中 调 色 板 版 本 的 颜色 与 真 彩色 版 本 更 能 匹配 


imagecolorclosest 


imagecolorclosestalpha 


imagecolorclosesthwb 


imagecolordeallocate 


imagecolorresolve 取得 指定 颜色 的 索引 值 或 有 可 能 得 到 的 最 接近 的 替代 值 
imagecolorresolvealpha 取得 指定 颜色 +alpha 的 索引 值 或 有 可 能 得 到 的 最 接近 的 替代 值 
imagecolorset 给 指定 调 色 板 索引 设 定 颜色 


取得 某 索引 的 颜色 


imagecolorsforindex 
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imagecolorstotal 取得 一 幅 图 像 的 调 色 板 中 颜色 的 数目 

imagecolortransparent 将 某 个 颜色 定义 为 透明 色 

imageconvolution 用 系数 div 和 offset 申 请 一 个 3x3 的 卷 积 窍 阵 

imagecopy 复制 图 像 的 一 部 分 

imagecopymerge 复制 并 合并 图 像 的 一 部 分 

dopingeiey 用 灰 度 复制 并 合并 图 像 的 一 部 分 

imagecopyresampled 重 采样 复制 部 分 图 像 并 调整 大 小 

imagecopyresized 复制 部 分 图 像 并 调整 大 小 

imagecreate 新 建 一 个 基于 调 色 板 的 图 像 

imagecreatefromgd2 从 GD2 文 件 或 URL 新 建 一 图 像 

imagecreatefromgd2part 从 给 定 的 GD2 文 件 或 URL 中 的 部 分 新 建 一 图 像 

imagecreatefromgd 从 GD 文件 或 URL 新 建 一 图 像 

imagecreatefromgif 从 GIF 文件 或 URL 新 建 一 图 像 

imagecreatefromjpeg 从 JPEG 文 件 或 URL 新 建 一 图 像 

imagecreatefrompng 从 PNG 文 件 或 URL 新 建 一 图 像 

imagecreatefromstring 从 字符 串 中 的 图 像 流 新 建 一 图 像 

imagecreatefromwbmp 从 WBMP 文 件 或 URL 新 建 一 图 像 

imagecreatefromxbm 从 XBM 文 件 或 URL 新 建 一 图 像 

imagecreatefromxpm 从 XPM 文 件 或 UR 新 建 一 图 像 

imagecreatetruecolor 新 建 一 个 真 彩色 图 像 

imagedashedline 画 一 虚线 

imagedestroy 销毁 一 图 像 

imageellipse 画 一 个 椭圆 

imagefill 区 域 填充 

imagefilledarc 画 一 椭圆 弧 且 填充 

imagefilledellipse 画 一 椭圆 并 填充 

imagefilledpolygon 画 一 多 边 形 并 填充 

imagefilledrectangle 画 一 矩形 并 填充 

imagefilltoborder 区 域 填充 到 指定 颜色 的 边界 为 止 

imagefilter 对 图 像 使 用 过 滤器 

imagefontheight 取得 字体 高 度 

imagefontwidth 取得 字体 宽度 

imageftbbox 给 出 一 个 使 用 FreeType2 字 体 的 文本 框 

imagefttext 使 用 FreeType2 字 体 将 文本 写 入 图 像 

imagegammacorrect 对 GD 图 像 应 用 gamma 修 正 

imagegd2 将 GD2 图 像 输出 到 浏览 器 或 文件 

imagegd 将 GD 图 像 输 出 到 浏览 器 或 文件 

imagegif 以 GE 格式 将 图 像 输出 到 浏览 器 或 文件 
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imageinterlace 激活 或 禁止 隔行 扫描 
imageistruecolor 检查 图 像 是 否 为 真 彩色 图 像 
imagejpeg 以 JPEG 格 式 将 图 像 输出 到 浏览 器 或 文件 
imagelayereffect 设 定 alpha 混 色 标志 以 使 用 绑 定 的 libgd 分 层 效 果 
imageline 画 一 条 线段 
imageloadfont 载 入 一 新 字体 
imagepalettecopy 将 调 色 板 从 一 幅 图 像 复 制 到 另 一 幅 
imagepng 以 PNG 格 式 将 图 像 输出 到 浏览 器 或 文件 
imagepolygon 画 一 个 多 边 形 
imagepsbbox 给 出 一 个 使 用 PostScript Typel 字 体 的 文本 方 框 
imagepsencodefont 改变 字体 中 的 字符 编码 矢量 
imagepsextendfont 扩充 或 精简 字体 
imagepsfreefont 释放 一 个 PostScript Typel 字 体 所 占用 的 内 存 
imagepsloadfont 从 文件 中 加 载 一 个 PostScript Typel 字 体 
imagepsslantfont 倾斜 某 字体 
imagepstext 用 PostScript Typel 字 体 把 文本 字符 串 画 在 图 像 上 
imagerectangle 画 一 个 矩形 
imagerotate 用 给 定 角度 旋转 图 像 
imagesavealpha 设置 标记 以 在 保存 PNG 图 像 时 保存 完整 的 alpha 通 道 信息 “〈 与 单一 透明 色相 反 ) 
imagesetbrush 设 定 画 线 用 的 画笔 图 像 
imagesetpixel 画 一 个 单一 像素 
imagesetstyle 设 定 画 线 的 风格 
imagesetthickness 设 定 画 线 的 宽度 
imagesettile 设 定 用 于 填充 的 贴图 
imagestring 水 平地 画 一 行 字符 串 
imagestringup, 垂直 地 画 一 行 字符 串 
imagesx 取得 图 像 宽度 
imagesy 取得 图 像 高 度 
imagetruecolortopalette 将 真 彩色 图 像 转换 为 调 色 板 图 像 
imagettfbbox 取得 使 用 TrueType 字 体 的 文本 的 范围 
imagettftext 用 TrueType 字 体 向 图 像 写 入 文本 
imagetypes 返回 当前 PHP 版 本 所 支持 的 图 像 类 型 
imagewbmp 以 WBMP 格 式 将 图 像 输 出 到 浏览 器 或 文件 
imagexbm 将 XBM 图 像 输出 到 浏览 器 或 文件 
iptcembed 将 二 进 制 [PTC 数 据 嵌 入 到 一 幅 JPEG 图 像 中 
iptcparse 将 二 进 制 [PTC http://www.iptc.org/ 块 解析 为 单个 标记 
jpeg2wbmp 将 PEG 图 像 文件 转换 为 WBMP 图 像 文件 
png2wbmp, 将 PNG 图 像 文 件 转换 为 WBMP 图 像 文件 
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从 表 10.2 可 以 看 出 ，PHP 的 GD 库 函 数 功 能 相当 丰富 ， 几 乎 涵盖 了 图 像 处 理 中 的 所 有 内 容 。 下 面 
将 通过 几 节 内 容 为 读者 介绍 常用 的 GD 库 函 数 的 使 用 方法 。 


102 ”图像 使 用 实战 


从 10.1 节 读 者 已 经 领会 了 GD 库 的 强大 功能 。 这 一 节 将 用 3 小 节 的 内 容 介绍 常用 的 GD 库 函 数 的 
使 用 方法 。 内 容 包 括 : 如 何 创 建 图 形 ， 如 何在 图 形 上 画图 ， 绘 制 几何 图 形 ， 在 图 形 上 写字 等 。 从 中 读 
者 能 够 学 习 到 常用 GD 库 函 数 的 使 用 及 图 像 处 理 的 技巧 。 


10.2.1 使 用 GD 库 函 数 创建 图 像 
在 使 用 一 个 图 像 之 前 必须 要 先 创建 它 。 通 过 查看 表 10.2 中 的 GD 库 函 数列 表 可 以 发 现 ， 要 创建 一 
个 图 像 就 使 用 imagecreate() 函 数 。 它 的 使 用 格式 如 下 所 示 : 


resource imagecreate(int x_size,int y_size) 


参数 x_size、y_size 为 整 型 变量 ， 内 容 为 所 创建 图 像 的 宽 与 高 。 该 函数 返回 一 个 图 像 标 识 符 ， 代 表 
了 一 幅 宽 与 高 为 x_size，y_size 的 空白 图 像 。 


注意 : 由 于 要 向 浏览 器 输出 一 幅 图 像 ， 所 以 使 用 此 函数 之 前 要 使 用 header("Content-type: image/png"); 
并 且 在 使 用 header() 函 数 之 前 不 能 有 任何 内 容 的 输出 。 


下 面 使 用 一 个 实例 来 说 明 如 何 使 用 imagecreate0 函 数 ， 具 体内 容 参看 以 下 代码 : 


<? 

header("Content-type:image/png"); // 向 浏览 器 输出 文件 头 
$im=imagecreate(100,50); /使 用 函数 创建 图 像 
$background color = imagecolorallocate($im,255,255,255); /设置 背景 色 
Stext_color = imagecolorallocate($im,233,14,91); /定义 文本 内 容颜 色 
imagestring($im,1,5,5,"A Simple Text String", $text_color); // 写 文本 
imagepng($im); /| 输出 PNG 
imagedestroy($im); /销毁 图 像 

?> 


把 以 上 代码 保存 为 “10-2.php”， 在 PHP 执行 环境 中 运行 该 文件 ， 其 执行 结果 如 图 10.2 所 示 。 
| huo: //127-0-0. EN 


文件 中 RaO FEV HRO ” P 


emm 
10.2 imagecreate() 函 数 使 用 实例 执行 结果 


通过 该 实例 及 其 执行 结果 可 见 创建 一 个 图 像 的 过 程 。 先 创建 图 像 ， 再 在 图 像 上 进行 操作 。 本 例 实 
现 的 效果 是 先 创建 一 个 图 像 ， 再 把 文本 输出 到 已 经 存在 的 图 像 上 。 
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10.22 ”创建 图 形 并 在 上 面 画 图 


10.2.1 小 节 介 绍 了 如 何 创 建 图 形 ,图 形 创建 后 , 就 是 如 何 操 作 的 问题 了 。 这 一 小 节 讲 解 如 何在 图 形 
上 面 画 出 几何 图 形 。GD 库 函 数 能 直接 在 图 像 上 绘制 直线 、 甜 形 、 圆 形 、 椭 圆 形 等 儿 何 图 形 。 下 面 来 分 


别 说 明 这 儿 个 函数 的 使 用 方法 : 


O bool imageline(resource image,int xl,int yl,int x2,int y2,int color) AL. 参数 image 为 一 个 已 经 创 


建 的 图 形 对 象 ， 参 数 xl, yl 


x2、y2 均 为 整 型 数 ，color 为 表示 颜色 的 整 型 数 〈 以 上 参数 在 


其 他 函数 中 有 相似 的 意义 不 再 重复 ) 。 执 行 函数 ， 将 会 用 color 颜色 画 一 条 从 x1，y1l 到 x2, 


y2 的 直线 。 


O bool imagerectangle(resource image,int xl,int yl,int x2,int y2,int col) 函 数 。 参 数 内 容 与 imageline() 


函数 相似 。 执 行 函 数 ， 将 会 用 
为 225 y2: 


color 颜色 画 一 个 矩形 ， 和 矩形 的 左上 角 为 xl, yl; A FER 


O bool imagefilledrectangle(resource image,int xlint yl,int x2,int y2,int color).。 执 行 函 数 ， 将 会 夯 
一 个 矩形 ， 与 上 一 个 函数 不 同 的 是 一 个 用 color 填 充 的 矩形 。 

O ”bool imageellipse(resource image,int cx,int cy,int w,int h,int color) 函 数 。 参 数 ex, cy, w, h 均 为 
整 型 数 。 执 行 函数 ， 将 会 画 一 个 颜色 为 color 的 椭圆 ， 该 椭圆 的 左上 角 为 ex，cy，w、h 为 椭 
圆 的 宽度 和 高 度 ， 如 果 两 者 相等 画 出 的 就 是 一 个 正 圆 形 。 

O ”bool imagefilledellipse(resource image,int cx,int cy,int w,int h,int color) 函 数 。 基 本 内 容 同 上 也 是 


绘制 椭圆 ， 不 同 的 是 此 函数 画 : 


的 椭圆 也 是 填充 的 实心 图 形 。 


介绍 了 以 上 几 个 函数 ， 下 面 就 通过 实例 来 向 读者 说 明 如 何 使 用 这 些 函 数 绘制 几何 图 形 ; 


<? 

header("Content-type:image/png"); // 向 浏览 器 输出 文件 头 
$im=imagecreate(500,500); /使 用 函数 创建 图 像 
$black=imagecolorallocate($im, 0,0,0); /定义 黑色 
$white=imagecolorallocate($im, 255,255,255); /定义 和 白色 
$yellow=imagecolorallocate($im,255,255,0); /定义 黄色 

$blue =imagecolorallocate($im,0,0,255); /定义 蓝 色 
S$red=imagecolorallocate($im,255,0,0); /定义 红色 
$zi=imagecolorallocate($im,255,0,255); /定义 紫色 
$background_color = imagecolorallocate($im,255,255,255); // 设 置 背景 色 
imageline($im,10,10,350,10,$white); /用 和 白色 画 直 线 
imagerectangle($im,20,20,200,100,$blue); // 用 蓝 色 画 一 个 矩形 
imagefilledrectangle($im,100,200,200,300, $yellow); // 用 黄色 画 一 个 填充 矩形 
imageellipse($im,50,50,150,150,$zi); // 用 紫色 画 一 个 椭圆 
imagefilledellipse($im,50,50,150,350, $white); 1/ 用 白色 画 一 个 正 圆 形 
imagepng($im); /输出 PNG 
imagedestroy($im); 1/ 销毁 图 像 

?> 


把 以 上 代码 保存 为 “10-3.php”。 然 


后 在 PHP 执行 环境 中 执行 该 文件 ， 其 执行 结果 如 图 10.3 所 示 。 
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图 103 使 用 GD 函数 在 图 像 上 绘制 几何 图 形 
通过 上 面 的 实例 及 执行 结果 ， 可 以 发 现 GD 库 函 数 几 乎 可 以 绘制 所 有 的 几何 图 形 。 通 过 自己 的 创 
意 ， 能 绘 出 更 多 的 项 目 。 


10.2.3 绘制 几何 图 形 更 多 的 探索 


本 节 利 用 GD 库 中 的 画 直线 函数 imageline() 来 做 更 多 的 探索 。 利 用 画 直线 函数 来 达到 画 三 角形 
画 五 角 星 及 更 复杂 图 形 的 目的 。 

再 复杂 的 图 形 归根 结 底 都 是 由 简单 的 直线 或 者 曲线 构成 的 ， 只 要 掌握 了 构图 的 规律 ， 就 可 以 用 简 
单 的 直线 来 描绘 出 复杂 的 图 形 。 下 面 的 例子 实现 了 用 直线 画 正三 角形 。 有 具体 内 容 参 见 以 下 代码 : 


<? 

header("Content-type:image/png"); // 向 浏览 器 输出 文件 头 
$im=imagecreate(400,300); // 使 用 函数 创建 图 像 
$white=imagecolorallocate($im, 255,255,255); // 定 义 白色 
$background_color = imagecolorallocate($im,255,255,255); 1/ 设置 背景 色 
imageline($im,100,50,300,50, $white); // 画 线 
imageline($im,100,50,200,50+200*sin(pi()/3),$white); // 画 线 
imageline($im,200,50+200*sin(pi()/3),300,50,$white); // 画 线 
imagepng($im); // 输 出 PNG 
imagedestroy($im); // 销 毁 图 像 

?> 


保存 以 上 代码 为 “10-4.php”。 然 后 ， 在 PHP 执行 环境 中 运行 该 PHP 文件 ， 其 执行 结果 如 图 10.4 
所 示 。 

既然 能 用 画 直 线 函 数 画 出 正三 角形 ， 当 然 也 可 以 用 它 来 绘制 五 角 星 了 。 下 面 的 代码 就 实现 了 用 画 
直线 函数 绘制 五 角 星 : 

<? 


header("Content-type:image/png"); // 向 浏览 器 输出 文件 头 
$im=imagecreate(400,400); // 使 用 函数 创建 图 像 
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$black=imagecolorallocate($im, 0,0,0); 
S$white=imagecolorallocate($im, 255,255,255); 
$red=imagecolorallocate($im,255,0,0); 


$background_color = imagecolorallocate($im,255,255,255); 


imagefilledrectangle($im,5,5,395,395,$white); 
$m=200; 
$n=sqrt($m*$m+$m*$m-2*$m*$m*cos(3*pi()/5)); 
$a=cos(2*pi()/5)*$n; 

$b=sin(2*pi()/5)*$n; 

$c=cos(pi()/5)*$mi; 

$d=sin(pi()/5)*$m; 
imageline($im,200,50,200-$a,50+$b,$red); 
imageline($im,200,50,200+$a,50+$b,$red); 
imageline($im,200-$c,50+$d,200+$a,50+$b,$red); 
imageline($im,200+$c,50+$d,200-$a,50+$b,$red); 
imageline($im,200-$c,50+$d,200+$c,50+$d,$red); 
imagepng($im); 

imagedestroy($im); 

?> 


/定义 黑色 

// 定 义 白色 

/定义 红色 

// 设 置 背景 色 

/用 和 白色 画 一 个 矩形 

// 边 长 

/大 边 长 

// 设 置 变量 以 求 顶点 坐标 


// 画 线 

// 画 线 
// 画 线 
// 画 线 
// 画 线 

// 输 出 PNG 
// 销 毁 图 像 


保存 以 上 代码 为 “10-5.php”。 然 后 在 PHP 执行 环境 中 运行 该 文件 ， 执 行 结果 如 图 10.5 所 示 。 
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图 10.4 用 画 直 线 函 数 绘制 正三 角形 图 10.5 使 用 画 直线 函数 绘制 五 角 星 
对 于 此 五 角 星 来 说 ， 画 线 的 过 程 相当 简单 。 主 要 是 利用 数学 原理 来 求 各 个 顶点 的 坐标 相对 麻烦 。 


<? 

header("Content-type:image/png"); 
S$im=imagecreate(420,420); 
$black=imagecolorallocate($im, 0,0,0); 
S$white=imagecolorallocate($im, 255,255,255); 
$blue=imagecolorallocate($im,0,0,255); 


$background_color = imagecolorallocate($im,255,255,255); 


imagefilledrectangle($im,5,5,415,415,$white); 


下 面 再 通过 一 个 例子 ， 使 用 画 线 函 数 imageline() 来 绘制 正 十 二 角 星 。 具 体内 容 参 看 以 下 代码 : 


// 向 浏览 器 输出 文件 头 
// 使 用 函数 创建 图 像 
// 定 义 黑色 

/定义 和 白色 

/定义 蓝 色 

// 设 置 背景 

// 用 和 白色 画 一 个 矩形 


“iia 
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imageline($im,210,10,110,210+100*sqrt(3), $blue); // 画 线 
imageline($im,210,10,310,210+100*sqrt(3),$blue); // 画 线 
imageline($im,210,410,110,210-100*sqrt(3),$blue); IBR 
imageline($im,210,410,110,210+100*sqrt(3),$blue); // 画 线 
imageline($im,10,210,210+100*sqrt(3),110, $blue); // 画 线 
imageline($im,10,210,210+100*sqrt(3),310, $blue); // 画 线 
imageline($im,410,210,210-100*sqrt(3),110,$blue); // 画 线 
imageline($im,410,210,210-100*sqrt(3),310,$blue); // 画 线 
imageline($im,110,210-100*sqrt(3),210+100*sqrt(3),310,$blue); 。“// 画 线 
imageline($im,110,210+100*sqrt(3),210+100*sqrt(3),110,$blue); 。“// 画 线 
imageline($im,210-100*sqrt(3),110,310,210+100*sqrt(3),$blue); // 画 线 
imageline($im,210-100*sqrt(3),310,310,210-100*sqrt(3),$blue); Imik 
imagepng($im); // 输 出 PNG 
imagedestroy($im); // 销 毁 图 像 
?> 


保存 以 上 代码 为 “10-6.php”。 在 PHP 执行 环境 下 运行 该 文件 ， 其 执行 结果 如 图 10.6 所 示 。 
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图 10.6 ”使 用 画 直 线 函数 绘制 正 十 二 角 星 
通过 上 面 的 3 个 例子 ， 能 够 了 解 到 利用 GD 库 函 数 可 以 说 是 没有 做 不 到 的 ， 只 有 想不到 的 。 要 善 


于 利用 库 函 数 来 实现 特定 的 目的 。 


10.2.4 使 用 GD 库 函 数 在 图 片上 写字 


本 节 将 使 用 imagestring0) 函 数 在 一 张 已 经 存在 的 图 片上 写字 。 比较 常见 的 作用 是 当 用 户 把 图 片上 传 
到 服务 器 后 ， 通 过 PHP 程序 在 图 片上 打上 网 站 的 标记 ， 或 者 版 权 信 息 。 该 函数 的 使 用 格式 如 下 所 示 : 

bool imagestring(resource image,int font,int x,int y,string s,int col) 

SH image 为 一 个 已 经 打开 的 图 像 对 象 ， 参 数 x、y 为 整 型 变量 ， 内 容 为 已 经 打开 图 像 的 坐标 处 。 


参数 font 为 整 型 变量 ， 内 容 为 要 显示 的 字体 。 如 果 要 使 


日 中 文字 体 ， 则 要 把 该 字体 文件 放 到 程序 同一 


个 目录 下 。 参 数 string 为 字符 串 类 型 ， 内 容 即 为 要 写 的 文本 内 容 。 参 数 col 为 整 型 变量 ， 内 容 为 欲 打 印 
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文本 的 颜色 。 函 数 的 返回 值 为 布尔 型 变量 ， 即 如 果 成 功 打 印 文本 则 返回 True, FURRE False。 
下 面 通过 一 个 实例 来 说 明 如 何 使 用 imagestring0 函 数 在 一 张 图 片上 写字 。 具 体内 容 请 参看 以 下 代码 : 


<? 
header("Content-type:image/png"); /向 浏览 器 输出 文件 头 
$image="1.png"; /定义 变量 指向 图 像 文件 
$im=imagecreatefrompng($image); 
$yellow=imagecolorallocate($im,255,255,0); /定义 黄色 
$white=imagecolorallocate($im, 255,255,255); /定义 和 白色 
imagestring($im,4,5,5,"| like this game!", $yellow); /用 黄色 在 图 片上 写字 
imagestring($im,5,160,150,"TIAN ZHI HEN",$white); /用 和 白色 在 图 片上 写字 
imagepng($im); /输出 PNG 
imagedestroy($im); /| 销毁 图 像 
Kod 

\ APEI « ” WA 行 ECMA EE ,lolx 
保存 以 上 代码 为 10-7.php”。 然后 在 PHP 执行 XPO MD EV KO IAV ”| M 


环境 中 运行 该 文件 (在 执行 该 文件 之 前 , 要 把 “1.png” 
文件 放 到 10-7.php 的 同一 个 目录 下 ) ， 其 执行 结果 
如 图 10.7 所 示 。 

在 使 用 imagestring() 函 数 时 有 一 个 问题 需要 注 


意 , 这 个 函数 不 支持 中 文 ， 即 string 参数 只 能 为 英文 ed 
或 者 数字 。 不 过 可 以 通过 安装 Freetype 字体 来 解决 这 II 
个 问题 。 图 10.7 GD 库 函 数 在 图 片上 写字 


10.2.5 使 用 GD 库 函 数 绘制 直方 统计 图 


从 10.2.3，10.2.4 小 节 读 者 学 习 了 如 何 用 GD 库 函 数 创建 图 像 及 如 何在 图 片 文件 上 输出 字符 。 这 一 
小 节 为 读者 介绍 一 个 实用 的 例子 ， 用 GD 库 函 数 绘制 直方 统计 图 。 有 具体 内 容 参 看 以 下 代码 : 


<? 
/首先 定义 一 个 数组 ， 其 内 容 可 以 表示 为 一 个 工厂 全 年 生产 效益 
$num[0]=100; 
$num[1]=120; 
$num[2]=125; 
$num[3]=130; 
$num[4]=160; 
$num[5]=200; 
$num[6]=230; 
$num[7]=250; 
$num[8]=290; 
$num[9]=310; 


S$num[10]=400; 
$num[11]=200; 
Header("Content-type: image/png"); // 输 出 头 文件 


$im=imagecreate(500,450); 
$black=imagecolorallocate($im, 0,0,0); /定义 黑色 
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$white=imagecolorallocate($im, 255,255,255); // 定 义 白色 
$yellow=imagecolorallocate($im,255,255,0); /定义 黄色 
$blue =imagecolorallocate($im,0,0,255); /定义 蓝 色 
$red=imagecolorallocate($im,255,0,0); /定义 红色 
imageline($im,5,5,5,435,$white); // 画 出 纵 坐 标 
imageline($im,5,435,400,435,$white); // 画 出 横 坐 标 
for($i=0;$i<count($num);$i++) // 循 环 画 出 直方 图 
{ 

imagefilledrectangle($im, ($i+1)*30,440-$num[Si]-5, ($i+1)*30+20,435,$color); 
} 
for($i=0;$i<count(gnum):$i++) // 循 环 画 出 数值 
{ 

imagestring($im,4,($i+1)*30,440-$num[$i]-5,"$num[$i]",$blue); 
} 
for($i=1;$i<13;$i++) // 循 环 画 出 横 坐 标 单位 
{ 

imagestring($im,4,$i*30,430,"$i",$red); 
} 
for($i=0;$i<5;$i++) // 循 环 画 出 纵 坐 标 单位 
{ 

$s=$i*100; 

imagestring($im,4,5,435-$s,"$s",$white); 
} 
Imagepng($im); // 创 建 图 像 
Imagedestroy($im); // 关 闭 图 像 
?> 


保存 以 上 代码 为 “10-8.php”。 然 后 在 PHP 执行 环境 中 运行 该 文件 ， 其 执行 结果 如 图 10.8 所 示 。 
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图 10.8 使 用 GD 库 函数 绘制 直方 统计 图 使 用 实例 执行 结果 
通过 以 上 实例 及 执行 结果 可 以 看 出 GD 库 函 数 配合 数学 函数 可 以 画 出 功能 强大 的 数学 图 形 ， 可 以 
把 数字 内 容 变 为 直观 的 图 像 。 这 样 可 以 增加 程序 的 亲和力 ， 使 原本 枯燥 的 数字 更 容易 使 用 户 接受 ， 从 
而 增加 程序 的 易 用 性 。 
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10.2.6 用 GD 库 函 数 创建 图 像 的 缩 略 图 


161“ 


在 编写 Web 应 用 程序 时 ， 要 通盘 考虑 全 面 的 内 容 ， 如 网 页 加 载 时 打开 的 图 像 太 大 ， 就 会 延长 网 页 


打开 的 速度 ， 从 而 会 使 有 的 用 


函数 创建 一 幅 图 像 的 缩 略 图 。 


户 失去 耐心 。 如 果 在 用 户 打 开 图片 前 ， 生 成 欲 打开 图 像 的 缩 略图 让 用 户 
了 解 大 致 情况 ， 就 会 好 得 多 。GD 库 函 数 就 有 创建 图 像 缩 略 图 的 功能 。 这 一 节 就 来 介绍 如 何 使 用 GD E 


在 介绍 程序 之 前 ， 先 来 认识 GD 库 函 数 imagecopyresized0。 它 的 使 用 格式 如 下 所 示 : 
int imagecopyresized(int dst_im,int src_im,int dstX,int dstY,int srcX,int srcY,int dstW,int dstH ,int srcW,int srcH); 
该 函数 可 以 复制 新 图 ， 并 重新 调整 图 片 的 大 小 尺寸 。 参 数 都 是 目的 在 前 ， 来 源 在 后 。 参 数 dst_im 
及 src_im 为 图 片 的 句柄 。 参 数 dstX、dstY、srcX、srcY 分 别 为 目的 及 来 源 的 坐标 。 参 数 dstW、dstH、 
sreW、srcH 分 别 为 目的 及 来 源 的 宽 及 高 ， 若 欲 调整 新 图 的 尺寸 就 在 这 里 设 定 。 
可 见 ， 通 过 此 函数 ， 就 可 以 达到 调整 图 片 大 小 的 目的 ， 生 成 缩 略图 自然 也 是 可 以 的 。 下 面 就 通过 


一 个 实例 来 向 读者 作 一 介绍 。 
<? 


具体 内 容 参见 以 下 代码 : 


function resizeimage($srcfile,$rate=.5) 


{ 


$size=getimagesize($srcfile); 


switch($size[2]) 
{ 


case 1: 


$img=imagecreatefromgif($srcfile); 


break; 
case 2: 


$img=imagecreatefromjpeg($srcfile); 


break; 
case 3: 


$img=imagecreatefrompng($srcfile); 


break; 


} 
$srcw=imagesx($img); 
$srch=imagesy($img); 


$dstw=floor($srcw*$rate); 
$dsth=floor($srch*$rate); 
$im=imagecreate($dstw,$dsth); 
$black=imagecolorallocate($im,255,255,255); 
imagefilledrectangle($im,0,0,$dstw,$dsth, $black); 
imagecopyresized($im,$img,0,0,0,0,$dstw,$dsth,$srcw,$srch); // 重 新 定义 新 图 像 


imagejpeg($im); 
imagedestroy($im); 
imagedestroy($img); 


} 
S$im1="1.jpg"; 


resizeimage($im1); 
?> 


// 建 立 一 个 函数 以 指定 比率 缩放 图 像 


// 判 断 图 片 类 型 及 大 小 
// 判 断 图 片 类 型 根据 类 型 创建 图 片 


// 源 图 片 的 宽度 

// 源 图 片 的 高 度 

// 目 的 图 片 的 宽度 

// 目 的 图 片 的 高 度 

// 新 建 一 个 真 彩色 图 像 
// 定 义 黑色 

// 画 一 个 图 色 的 矩形 


/以 JPG 格式 输出 新 图 像 

// 释 放 源 图 像 

// 释 放 目 的 图 像 

// 定 义 变量 

// 调 用 函数 参数 $rate 使 用 默认 参数 
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保存 以 上 代码 为 “10-9.php”。 然后 在 PHP 执行 环境 中 执行 以 上 代码 (注意 要 把 “1.jpg” 放 到 10-6.php 
的 同一 个 目录 下 ) ， 执 行 结果 如 图 10.9 所 示 。 


Dhtto://127.0.0. 1/test DID SiO 
Ed 


到 
CEM E23 YA 


图 10.9 用 GD 库 函 数 创建 图 像 的 缩 略 图 


通过 以 上 输出 的 图 像 ， 与 实际 使 用 的 “1jpg” 的 比较 ， 发 现 程序 正确 输出 了 源 图 像 的 缩 略 版 ， 达 
到 了 创建 缩 略 图 的 使 用 目的 。 

从 上 面 的 函数 也 可 以 看 出 ， 通 过 此 函数 不 仅 可 以 创建 缩 略 图 ， 而 且 可 以 实现 图 像 的 任意 大 小 的 缩 
放 。 可 见 GD 库 函 数 功 能 的 强大 。 


10.3 本 章 小 结 


这 一 章 为 读者 介绍 了 PHP 中 与 图 像 相关 的 函数 及 GD 库 函 数 ， 重 点 介绍 了 GD 库 函 数 。 通 过 几 个 
实例 学 习 了 几 个 常用 的 GD 库 函 数 。 本 章 知识 点 有 PHP 中 的 获取 图 像 信息 函数 getimagesize()、GD PF 
函数 的 使 用 、 用 GD 函数 创建 图 像 、 使 用 GD 库 函 数 绘制 几何 图 形 、 使 用 GD 库 函 数 在 图 片上 写字 和 
两 个 综合 实例 ， 即 用 GD 库 函 数 创 建 直方 统计 图 和 用 GD 库 函 数 创建 一 幅 图 像 的 缩 略图 。 通 过 本 章 的 
学 习 ， 用 户 对 GD 库 函 数 有 了 一 个 初步 的 了 解 。 更 多 更 深层 次 的 学 习 ， 需 要 在 运用 所 学 知识 解决 实际 
问题 过 程 中 领会 。 


alla 


PHP 中 的 Session 5 Cookie 
nai 


如 何 使 用 Session 
使 用 Session 时 有 的 注意 事项 
如 何 使 用 Cookie 


aa aa 


Cookie 综合 使 用 实例 


编写 Web 互动 程序 ， 保 存 用 户 的 登录 信息 是 十 分 必要 的 ， 这 样 可 以 提高 网 站 对 用 
户 的 吸引 力 。 目 前 常见 的 存储 机 制 有 两 种 : 一 种 是 把 用 户 信息 存储 于 服务 器 端的 主机 上 
的 Session; 另 一 种 是 把 用 户 信息 存储 于 客户 端 即 客户 机 上 的 Cookie (ditt) 。 这 两 
种 机 制 各 有 各 的 将 点 ， 这 一 章 就 来 为 污 者 介绍 PHP 中 的 Session 和 Cookie。 本 章 内 容 
包括 : Session 的 使 用 注意 事项 、 有 关 的 Session 函数 及 它们 的 使 用 方法 、Cookie 的 使 
用 .PHP 中 的 Cookie 相关 函数 及 使 用 .为 Cookie 设置 生命 期 和 Cookie 综合 运用 实例 。 
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11.1 Session 的 使 用 


Session 会 话 适合 于 存储 用 户 的 信息 量 比较 少 的 情况 。 如 果 用 户 需要 存储 的 信息 量 相 对 较 少 ， 并 且 
对 存储 内 容 不 要 求 长 时 间 存 储 时 ， 使 用 Session 把 信息 存储 于 服务 器 端 会 比较 适合 。Session 会 话 允 许 
用 户 注册 任意 数目 的 变量 并 保留 给 各 个 请 求 使 用 。 当 用 户 访问 网 站 时 ，PHP 会 自动 (如 果 php.ini 中 的 
session.auto start 被 设 为 1) 或 在 用 户 请 求 时 (由 session_start() 明 确 调用 或 session_register() 暗 中 调用 )》 
检查 请 求 中 是 否 发 送 了 特定 的 会 话 ID。 如 果 是 , 则 之 前 保存 的 环境 就 被 重建 。 这 一 节 就 为 读者 介绍 PHP 
中 Session 的 使 用 。 


11.1.1 如 何 使 用 Session 


PHP 中 有 多 个 Session 函数 来 实现 Session 的 定义 、 存 储 、 更 改 、 删 除 等 操作 。 有 了 这 些 函数 ， 使 
用 Session 就 变 得 相当 简单 了 。 这 一 小 节 就 为 读者 来 介绍 PHP 中 的 Session 函数 及 它们 的 使 用 。PHP 中 
常用 的 Session 函数 ， 详 见 表 11.1。 


表 11.1 常用 的 Session 相关 函数 


A 数 名 参数 及 返回 值 
ERRANAK AB Session, A | A A PANAT, 
session_start(void) 该 客户 已 在 Session 之 中 ， 则 连 上 原 m» TEsession_start() 


数 之 前 不 能 有 任何 的 内 容 输出 否则 就 
会 发 生 错误 

与 session_start() 函 数 一 样 ，session_ 
destroy() 函 数 也 没有 参数 ， 且 返回 值 也 
均 为 Tme 

若 无 可 选 参数 name 则 表示 单单 获取 目 
前 Session 名 称 ， 加 上 参数 则 表示 将 
Session 名 称 设 为 参数 name 

车 无 可 选 参数 module 则 表示 只 获取 目 
前 Session 的 模 组 ， 加 上 参数 则 表示 将 
Session 模 组 设 为 参数 module 

若 无 可 选 参数 path 则 表示 只 有 取得 目 
前 Session 的 路 径 目 录 名 ， 加 上 参数 path 
则 表示 将 Session 存 在 新 的 路 径 上 

车 无 参 数 id 则 表示 只 有 取得 目前 
本 函数 可 取得 或 者 重新 设 定 目前 存 | Session 的 代号 ， 加 上 参数 则 表示 将 
放 Session 的 代号 Session 代 号 设 成 新 指定 的 id。 输 入 及 传 
回 均 为 字 串 

本 函数 在 全 局 变量 中 增加 一 个 变量 | 参数 name 为 欲 检查 的 变量 名 。 如 果 注 册 
到 目前 的 Session 之 中 则 返回 True， 反 之 则 返回 False 


有 的 Session 


session destroy(void) 


session namef(string [name]) 


本 函数 可 取得 或 者 重新 设 定 目前 
Session 的 模 组 


session module namef(string [module]) 


本 函数 可 取得 或 者 重新 设 定 目前 存 
放 Session 的 路 径 


session save path(string [path]) 


session id(string [id]) 函 数 


session register(string name) 
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续 表 
函 数 名 作 用 参数 及 返回 值 

aa kii kaya Wasaa mahakani 部 ,omegp 为 从 天 除 的 变量 名 .成 功 则 

session_unregister(string name) 反 为 ， 功 能 是 在 目前 的 Session 之 中 返回 True 值 ， 反 之 则 返回 False 
删除 全 局 变量 上 的 变量 

PEER . 本 函数 可 以 检查 某 个 变量 名 是 否 已 | 参数 name 为 欲 检查 的 变量 名 。 如 果 注 册 

0 人) 经 被 注册 为 Session 则 返回 True， 反 之 则 返回 False 
参 BAR Fe j 

session_decode(string data) 本 函数 可 将 Session 内 的 资料 解码 waa pe S RE 

; ji 本 函数 可 将 Session 资 料 编码 ， 编 码 | 本 函数 没有 参数 。 成 功 则 返回 True 值 ， 
ee 以 ZEND 引 擎 做 杂凑 编码 否则 返回 False 


下 面 通过 一 个 实例 来 说 明 如 何在 PHP 中 使 用 Session， 具 体内 容 参看 以 下 代码 。 以 下 代码 实现 了 判 
Wi Session 变量 是 否 被 注册 ， 注 册 Session 变量 和 显示 Session 变量 的 功能 : 


<? 

session start(); // 开 始 使 用 session 

?> 

<html> 

<head> 

<title>session 使 用 实例 </title> 

</head> 

<body> 

<? 

$usemame1-"guest"; // 定 义 变量 

if(Isession is registered("username")) /| 判断 session 是 否 被 注册 
session_register("username"); /| 注册 session 
$_session["username"]=$username1; ”// 给 session 变量 赋值 

echo $_session["usemame"]; /显示 session 

session_destroy(); /| 结束 session 

?> 

</body> 

</html> 


保存 以 上 代码 为 “11-1.php”。 在 PHP 执行 环境 中 运行 该 文件 (此 时 的 register_globals=on) , 


执行 结果 如 图 11.1 所 示 。 

通过 上 面 的 例子 及 执行 结果 可 以 发 现 , 程序 正确 的 执行 
了 相关 操作 。 它 的 运行 机 制 为 程序 先 判断 名 字 为 “username” 
的 Session 有 没有 被 注册 ， 如 果 没 有 则 注册 Session 变量 , 并 
赋值 。 然 后 把 名 字 为 “username” 的 Session 变量 的 内 容 显 11.1 session 使 用 实例 执行 结果 
示 出 来 。 


11.1.2 Session 使 用 实例 
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上 面 的 例子 只 是 Session 最 简单 的 应 用 ， 实 际 上 Session 能 做 的 事情 远 不 止 于 此 ， 它 能 存储 多 种 信 


证 


结合 程序 能 做 更 多 的 事情 ， 如 以 下 代码 就 使 


Session 实现 了 一 个 简单 的 站 点 计数 器 : 


<? 
session_start(); 
if(lsession is registered(count')) 


{ 


// 开 始 使 用 Session 
// 如 果 没有 注册 Session 


session register('count'); 
$count=1; 


// 注 册 Session 
l/count 变量 为 1 


else 


{ 


$count++; 


// 如 果 已 经 注册 Session 


// 变 量 在 原 有 基础 上 增加 1 
} 

?> 

<html> 

<head> 

<title> 使 用 session 的 网 页 计数 器 </title> 

</head> 

<body> 

<p> 

你 好 ， 你 已 经 浏览 本 网 页 <?php echo $count; ?> 次 
</p> 

</body> 

</html> 


保存 该 代码 为 “11-2.php” 文 件 。 然 后 在 PHP 
执行 环境 中 运行 该 文件 ， 其 执行 结果 将 会 如 图 11.2 
所 示 。 

从 图 11.2 中 可 以 了 解 到 ， 该 页 面 注册 了 $count 图 
变量 为 Session。 并 且 随 着 刷新 ，$count 的 数量 也 随 一 一 一 一 一 - 
之 增加 ， 这 样 就 实现 了 统计 浏览 次 数 的 目的 。 11.2 使 用 session 的 网 页 计数 器 执行 结果 


轨 售 用:。:…ion 的 同 页 计 小 加 ~ ore 于 [| 
HD mao srv sw rao | | 


你 好 ， 你 己 经 测定 本 网 页 1 次 


11.1.3 ”使 用 Session 的 注意 事项 


在 使 用 Session 时 有 下 列 事项 需要 引起 注意 : 


O 如果 在 PHP.ini 文件 中 启用 了 session.auto_start， 就 不 能 将 对 象 放 入 会 话 中 ， 因 为 类 定义 必须 


在 启动 会 话 之 前 加 载 以 在 会 话 中 重建 对 象 。 


口 ”请 求 结束 后 所 有 注册 的 变量 都 会 被 序列 化 。 已 注册 但 未 定义 的 变量 被 标记 为 未 定义 。 在 此 后 


的 访问 中 这 些 变量 也 不 会 被 会 话 模块 定义 ， 除 非 用 户 以 后 定义 它们 。 


口 另外 有 些 类 型 的 数据 不 能 被 序列 化 ， 因 此 也 就 不 能 保存 在 会 话 中 。 包 括 resource 对 象 类 型 变 
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量 或 者 有 循环 引用 的 对 象 〈 即 某 对 象 将 一 个 指向 自己 的 引用 传递 给 另 一 个 对 象 ) 。 

默认 情况 下 ， 所 有 与 特定 会 话 相关 的 数据 都 被 存储 在 由 php.ini 文件 的 session.save_path 选项 
所 指定 的 目录 下 的 一 个 文件 中 。 对 每 个 会 话 建立 一 个 文件 〈 不 论 是 否 有 数据 与 该 会 话 相 关 ) 。 
这 是 由 于 每 打开 一 个 会 话 即 建立 一 个 文件 ， 不 论 是 和 否 有 数据 写 入 到 该 文件 中 。 注 意 由 于 和 文 
件 系统 协同 工作 的 限制 ， 此 行为 有 个 副作用 ， 有 可 能 造成 用 户 定制 的 会 话 处 理 器 〈 例 如 用 数 
WE) 丢失 未 存储 数据 的 会 话 。 

如 果 php.ini 的 配置 没有 开启 register_globals, 则 只 可 以 用 _SESSION 数组 来 引用 Session 变量 。 
如 , 注册 的 $var 变量 只 能 这 样 引用 “$_SESSION["var"]”。 而 如 果 开启 了 register_globals 选项 ， 
则 可 以 直接 使 用 $var。 

由 于 Cookie 存在 于 客户 端 ， 所 以 它 可 以 被 设置 为 长 时 间 甚 至 是 无 限期 存在 。 而 Session 因为 
是 存储 在 服务 器 端 ， 所 以 它 的 生命 期 很 短 。 注 册 过 的 变量 过 段 时 间 就 会 自动 失效 。 


11.2 Cookie 的 使 用 


11.1 节 给 读者 介绍 了 PHP 中 关于 Session 的 使 用 ,这 一 节 来 为 读者 介绍 PHP 中 Cookie 的 使 用 。 通 
过 本 节 的 学 习 ， 将 会 使 读者 对 PHP 中 的 Cookie 的 使 用 有 一 个 深刻 的 理解 。 并 且 能 够 使 用 Cookie 去 实 
际 处 理 一 些 问题 。 


T21 


为 什么 使 用 Cookie 


同样 作为 互动 Web 页 的 存储 机 制 Session 与 Cookie 有 其 相似 之 处 。 那 为 什么 在 有 了 Session 后 还 
要 使 用 Cookie 呢 ? 因为 同 Session 相 比 Cookie 有 其 独特 之 处 。 下 面 就 来 说 明 一 下 二 者 的 异同 ， 比 较 过 
二 者 的 异同 后 ， 读 者 就 会 明白 为 什么 要 用 Cookie 了 。 


口 


口 


口 


Cookie 保存 在 客户 端 ， 而 Session 的 内 容 保存 在 服务 器 端 ， 只 是 把 一 个 session id 保存 在 客户 
端 。 也 就 是 说 , Cookie 比 Session 更 安全 , 同时 也 可 以 说 明 Session 是 基于 Cookie 的 (用 Cookie 
来 保存 session id) 。 

由 于 Session 是 保存 在 服务 器 端的 ， 因 此 会 占用 服务 器 的 空间 ,所 以 在 一 定时 间 内 如 果 没 有 活 
动 时 Session 就 会 过 期 ， 而 且 在 浏览 器 关闭 后 也 会 作废 。 而 Cookie 就 没有 这 方面 的 限制 ， 它 
可 以 设 定 一 个 比较 长 的 过 期 时 间 。 

每 个 浏览 器 只 能 保存 同一 个 域名 下 的 至 多 20 个 Cookie， 而 且 每 个 Cookie 的 大 小 不 能 超过 
4KB， 而 Session 就 没有 这 些 限制 〈 因 为 保存 在 服务 器 端 ) o 

有 些 人 会 禁止 浏览 器 接受 Cookie， 而 此 时 Session 还 是 可 以 用 的 (注意 session 也 可 以 不 通过 
Cookie 来 实现 ) 。 


通过 以 上 比较 可 以 发 现 : Cookie 与 Session 各 有 各 的 用 处 ， 各 有 各 的 特点 ， 两 者 不 能 够 相互 奉 代 。 
11.2.2 小 节 将 来 了 解 一 下 ， 在 PHP 中 如 何 使 用 Cookie. 
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11.2.2 怎样 使 用 Cookie 


在 PHP 中 使 用 Cookie 很 简单 ， 简 单 到 只 用 一 句 函数 就 可 以 注册 Cookie 变量 ， 这 个 函数 是 
setcookie()。 其 使 用 格式 如 下 所 示 : 

bool setcookie(string name[string value[int expire[string path[string domain[bool secure[bool httponly]]]]] ) 

本 函数 会 跟着 文件 头 信息 header 送出 一 段 信 息 字 串 到 浏览 器 。 由 于 是 同 header 一 起 发 送 ， 所 以 该 
函数 同 其 他 header 函数 一 样 ， 在 执行 前 不 能 有 任何 的 HTML 输出 。 实 际 上 Cookie 也 算 标 头 的 一 部 份 。 

setcookie() 函 数 的 参数 除了 第 1 个 name 之 外 ， 都 是 可 以 省 略 的 。 参 数 name 表示 Cookie 的 名 称 ; 
value 表 示 这 个 Cookie 的 值 , value 参数 为 空 字 串 则 表示 取消 浏览 器 中 名 称 为 name 的 Cookie 的 值 ; expire 
表示 该 Cookie 的 有 效 时 间 ; path 为 该 Cookie 的 相关 路 径 ; domain 表示 Cookie 的 网 站 ; secure 则 需 在 
https 的 安全 传输 时 才 有 效 。 

下 面 用 一 个 实例 来 说 明 如 何在 PHP 中 使 用 setcookie() 函 数 来 定义 并 使 用 Cookie。 具 体内 容 参 见 以 
下 代码 。 下 面 为 文件 “11-3.php” 的 内 容 : 


<? 


$username=$_GET["username"]; /通过 URL 获得 参数 

if(!$_GET["usemame"]) // 如 果 没 有 参数 执行 内 容 

{ 

setcookie("usemame",""); /取消 username 的 资料 

echo "没有 指定 用 户 名 !"; 

echo "<p>"; 

echo "或 者 用 户 名 不 存在 !"; 

} 

else // 如 果 存 在 参数 
setcookie("username","$username"); /注册 用 户 名 
echo "注册 成 功 ， 点 <a href=11-4.php> 这 里 </a> 查 看 "; /显示 链接 以 查看 Cookie 信息 

} 

?> 

<html> 

<head> 

<title> 注 册 用 户 信息 </title> 

</head> 

<body> 

</body> 

</html> 

保存 下 面 的 代码 为 “11-4.php” 文 件 : 

<html> 

<head> 

<title> 显 示 用 户 信 息 </title> 

</head> 


<body> 
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<? 
echo "注册 用 户 名 为 :"; 
echo $_COOKIE[username]; / 旺 示 Cookie 信息 


分 别 保存 以 上 两 个 文件 为 “11-3.php” 与 “11-4.php”。 然 后 在 PHP 执行 环境 中 运行 11-3.php， 不 
带 任何 参数 ， 其 执行 结果 如 图 11.3 所 示 。 

如 果 加 上 “username” 参 数 ， 如 “11-3.php?username=guest” 再 次 运行 ， 效 果 就 会 不 一 样 。 其 执行 
结果 如 图 11.4 所 示 。 


马 计 作用 户 信息 - Microsoft Taterasi E 忆 计 全 用 户 信息 - Wi crosoft_ katernsi EI 


Ix| 
ET ET 
祝 有 指定 用 户 名 | mi 注册 成 功 ， 点 这 里 查看 i 
或 者 用 户 名 不 存在 | | i 
POE E OE E Zi 
11.3 不 带 参数 执行 11-3.php 的 执行 结果 图 11.4 加 上 参数 后 执行 11-3.php 的 执行 结果 
这 里 已 经 把 username 注册 为 Cookie 其 值 为 “guest”， 然 后 单 击 “ 这 里 ”链接 ， 将 会 出 现 11-4.php 
的 执行 情况 ， 如 图 11.5 所 示 。 EE gen 
图 11.5 显示 出 了 所 注册 的 用 户 名 。 说 明 Cookie sre mo me mw maoa 


注册 用 户 名 为 ，guest 


已 经 设置 成 功 。 由 于 没有 给 Cookie 设置 生命 期 ， 
所 以 该 Cookie 的 值 会 随 着 浏览 器 的 关闭 而 中 止 。 
如 果 要 保持 Cookie 的 值 长 期 有 效 ， 为 其 设置 生命 
期 是 有 必要 的 。11.2.3 小 节 将 为 读者 讲解 。 


到 
zi 


EI EC 


图 11.5 11-4.php 的 执行 结果 


11.2.3 ”设置 Cookie 生命 期 


在 实际 使 用 PHP 编写 Web 应 用 程序 时 ， 为 了 方便 用 户 ， 需 要 对 Cookie 设置 生命 期 。 有 的 论坛 在 
登录 时 就 会 有 个 选择 ， 保 存 用 户 登录 记录 ， 并 且 还 可 以 设置 时 间 ， 如 ， 保 存 一 个 月 、 三 个 月 、 甚 至 是 
一 年 。 

其 实 保存 用 户 登录 记录 的 实质 就 是 保存 了 用 户 的 登录 信息 Cookie 到 用 户 客户 机 上 。 并 且 为 该 
Cookie 设置 了 较 长 的 生命 期 ， 这 样 就 避免 了 用 户 再 次 登录 时 ， 和 需要 重新 输入 的 问题 。 

如 何 为 Cookie 设置 生命 期 ? 从 11.2.2 小 节 中 讲 到 setcookie() 函 数 时 就 提 到 了 这 个 问题 ， 就 是 函数 
的 第 3 个 参数 expire， 它 的 作用 就 是 为 Cookie 设置 生命 期 。 如 果 这 一 项 为 补 ， 就 说 明 为 最 短 生命 期 ， 
即 随 着 浏览 器 的 关闭 而 中 止 。 那 么 只 要 带 有 expire 参数 ， 就 说 明 要 为 Cookie 设置 生命 期 ， 其 单位 为 日 
期 和 时 间 。 一 般 采 用 这 种 样式 : 

time()+N 


其 中 的 time0 表 示 当 前 时 间 ， 后 面 的 N 表示 秒 数 。timeO+N 的 意思 就 是 在 当前 时 间 后 多 少 秒 过 期 。 
如 果 要 设置 过 期 时 间 为 一 天 就 这 样 表 示 : 
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setcookie(name,value,time()+60*60*24); 

其 中 的 60*60*24 即 表示 一 天 。 因 为 一 天 有 24 小 时 ， 一 小 时 有 60 分 钟 ， 一 分 钟 有 60 秒 。 以 上 代 
码 即 表示 设置 name 的 值 为 value 的 Cookie 变量 有 效 期 为 从 当前 时 间 起 24 小 时 ， 即 一 天 一 夜 。 

知道 了 如 何 设置 一 天 ， 那 么 ， 设 置 一 月 ， 甚 至 一 年 都 可 以 触 类 旁 通 了 。 如 设置 有 效 期 为 一 月 就 这 
样 表示 : 

setcookie(name,value,time()+60*60*24*30); 

同 理 ， 设 置 一 年 有 效 期 就 要 像 这 样 : 

setcookie(name,value,time()+60*60*24*30*365); 

至 此 ， 相 信 读 者 对 如 何 为 Cookie 设置 生命 期 都 有 了 一 个 深刻 的 理解 。11.2.4 小 节 将 为 读者 介绍 
一 个 综合 应 用 的 实例 ， 来 实际 操作 一 下 Cookie。 


11.2.4 ”Cookie 综合 应 用 实例 一 一 网 页 风格 转换 


通过 前 几 小 节 的 介绍 ,读者 对 PHP 中 如 何 使 用 Cookie 有 了 一 个 比较 深刻 的 了 解 ， 这 一 节 ， 将 使 用 
一 个 综合 的 例子 来 向 读者 具体 说 明 在 PHP 中 如 何 使 用 Cookie。 


Cookie 常用 于 用 户 登录 记录 、 相 关 设置 记录 等 。 这 一 节 的 例子 就 来 为 读者 说 明 这 个 问题 。 具 体内 
容 参看 以 下 代码 ， 以 下 代码 为 11-5.php 前 台 界 面 代码 : 

<html> 

<head> 

<title> 用 户 登 录 前 台 </title> 

</head> 

<body topmargin="100"> 

<center> 


<table border=1> 

<form method=post action=11-6.php> 

<tr> 

<td> 请 输入 用 户 名 : </td> 

<td><input type=text name=usemame size=20></td> 
</tr> 

<tr> 

<td> 请 输入 密码 :</td> 

<td><input type=password name=password size=20></td> 
</tr> 

<tr> 

<td> 请 选择 保存 期 限 : </td> 

<td> 

<select name=time size=1> 

<option value=1> 不 保存 

<option value=2> 保 存 一 天 

<option value=3> 保 存 一 月 

<option value=4> 保 存 一 年 

</select> 

</td> 
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</tr> 


<tr> 


<td colspan=2><input type=submit value=" 确 定 "></td> 


</tr> 
</form> 
</table> 
</center> 
</body> 
<html> 


下 面 的 代码 为 11-6.php 后 台 执行 代码 。 


<? 
$username=$_POST["username"]; 
$time=$_POST["time"]; 
if(!$_POST["username"]) 


echo "没有 输入 用 户 名 "; 
echo "<p>"; 
echo "点 <a href=11-5.php> 这 里 </a> 返 回 "; 
$ 
else 
f 
switch $time 
i 
case 1: 
$time=time(); 
break; 
case 2: 
$time=time()+60*60*24; 
break; 
case 3: 
$time=time()+60*60*24*30; 
break; 
case 4: 
$time=time()+60*60*24*30*365; 
break; 
setcookie("username","$username", $time); 
?> 
<html> 
<head> 
<title> 注 册 用 户 信息 </title> 
</head> 
<body> 
<? 


echo "注册 用 户 名 为 :" 
echo $_COOKIE["usemame"]; 
echo "Cookie 有 效 期 为 :"; 


/通过 POST 获得 参数 
/通过 POST 获得 time 变量 
/如果 没有 参数 执行 内 容 


// 如 果 存 在 参数 
// 判 断 有 效 期 


/注册 用 户 名 


Ini 


switch $time 
{ 


PHP 网 络 编程 从 入 门 到 精通 


分 别 保存 以 上 代码 为 “11-5.php” 与 “11-6.php”。 然 后 先 在 PHP 执行 环境 中 运行 11-5.php， 执 行 


结果 如 图 11.6 所 示 。 


然后 ， 按 照 上 面 内 容 输入 用 户 名 、 密 码 (因为 只 是 测试 Cookie， 所 以 其 实 这 两 项 都 是 虚拟 的 ， 并 


不 存在 用 户 数据 库 ， 


只 要 输入 内 容 就 行 ) 。 并 选择 相应 的 Cookie 保存 期 限 ， 然 后 单 击 “ 确 定 ” 按 钮 ， 


程序 开始 启用 11-6.php 的 后 台 操作 。 其 结果 如 图 11.7 所 示 。 


XPD MAD 查看 HRW IAV HWW 


BRaaRea Moo 


| 请 给 入 密码 。 | 
WAA, [TER =] 
mi 


AWAPA - Microsft Taterasti 
XRO PAD FEV KRO ALI 


注册 用 户 各 为 ，guest 
COOKIE 有 效 期 为 ， 一 月 


COOU KA 


图 11.6 ”11-5.php 执行 结果 
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图 11.7 后 台 处 理 后 的 执行 结果 


11-5.php 及 11-6.php 就 是 Cookie 用 于 简单 的 用 户 注册 登录 ， 并 保存 用 户 记录 的 情况 。 下 面 再 介绍 
一 个 实例 ， 用 Cookie 保存 用 户 选择 的 网 站 风格 。 某 些 网 站 或 者 论坛 具有 多 种 风格 供用 户 选择 ， 这 样 可 


以 满足 用 户 不 同 的 需求 。 


下 面 就 介绍 如 何 用 Cookie 来 改变 网 站 的 风格 。 具 体内 容 参看 以 下 代码 。 


先 来 编写 只 


<html> 
<head> 


一 名 PHP 代码 的 11-7.php 文件 ， 该 文件 中 大 部 分 内 容 均 为 标准 的 HTML 内 容 : 
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<title>} cookie 实现 改变 网 站 风格 </title> 

<? 

echo "<LINK href='style".$_COOKIE["style"].".css' rel=stylesheet>"; /根据 Cookie 使 用 样式 
?> 

</head> 

<body> 

<table> 

<p> 用 Cookie 实现 改变 网 站 风格 </p> 

<tr> 

<td><a href=11-8.php?style=1> 风 格 1</a></td> 
<td><a href=11-8.php?style=2> 风 格 2</a></td> 
<td><a href=11-8.php?style=3> 风 格 3</a></td> 
<td><a href=11-8.php> 无 样式 </a></td> 

</tr> 

<tr> 

<td colspanz4><h1>HfE</h1></td> 

</tr> 

<tr> 

<td colspan=4><h2> 车 提 本 无 树 </h2></td> 
</tr> 

<tr> 

<td colspan=4><h2> 了 明镜 亦 非 台 </h2></td> 
</tr> 

<tr> 

<td colspan=4><h2> 本 来 无 一 物 </h2></td> 
</tr> 

<tr> 

<td colspan=4><h2> 何 处 车 尘埃 </h2></td> 
</tr> 

</table> 

</body> 

</html> 


下 面 来 编写 处 理 提 交 样式 的 PHP 文件 11-8.php。 其 功能 是 根据 提交 内 容 注册 相应 的 Cookie。 并 在 
处 理 后 返回 11-7.php: 


<? 

$style=$_GET["style"]; // 判 断 参数 来 源 
setcookie("style","$style",time()+60*60*24); // 根 据 参数 注册 Cookie 
?> 

<html> 

<head> 

<title> 正 在 处 理 </title> 

</head> 

<meta http-equiv="refresh" content="0; url=11-7.php"> 

<body> 正 在 处 理 

</body> 


另外 在 使 用 这 个 实例 之 前 还 要 编写 相应 的 CSS 文件 ， 并 命名 为 “stylel.css”、 “style2.css”、 
“style3.css”。 这 3 个 CSS 文件 的 内 容 如 下 所 示 〔 作 相应 保存 即 可 》。 
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stylel.css: 
BODY, TD{ 
font : 400 normal 100% Arial, Helvetica, sans-serif; 
l 
A{ 
color: #FFD700; 
text-decoration: none; 
background: Black; 
width: 80px; 
padding: 3px; 
} 
A:hover 
{ 
background: Maroon; 
} 
H1{ 
background: #228B22 none; 
color: #FF6347; 
font-size: 150%; 
text-align: right; 
} 
H2{ 
background : #FFDEAD none; 
color : #000000; 
font-size : 110%; 
} 
P 
background: #A9A9A9 none; 
color: #2F4F4F; 
font: 400 normal 120% Arial, Helvetica, sans-serif; 
text-decoration: none; 
padding: 2% 2% 2% 2%; 
border: 1px solid Black; 
} 
style2.css: 
body { 
background-color: #FFFFF0; 
$ 
a{ 
background: #FFFFAA; 
text-decoration: none; 
} 
a:hover { 
background: #FFFFF0; 
border: thin solid Black; 
} 


h1{ 
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text-align: center; 


ia 


3 
h2{ 
text-align: center; 
} 
pi 
text-align: center; 
font-size: 20px; 
} 
style3.css: 
body ( 
background-color: #FFFFFO; 
background-image: urifimage001.jpg); 
} 
a{ 
text-decoration: none; 
background-color: #0000CD; 
color: White; 
font-size: 15px; 
} 
a:hover { 
background-color: Maroon; 
} 
hif 
text-align: center; 
background-color: #FAFAD2; 
color: Blue; 
} 
h2{ 
text-align: center; 
background-color: #F5F5DC; 
color: Green; 
border: 1px solid Black; 
} 
pi 
text-align: center; 
border: 5px ridge; 
font-size: 40px; 


由 于 style3.css 使 用 了 
个 目录 下 。 一 切 准备 就 绪 ， 
的 Cookie 变量 存在 ， 所 以 现在 不 使 


图 片 作为 背景 ， 


所 以 要 把 名 称 为 image001.jpg 的 图 片 放 到 该 css 文件 的 同一 


先 运行 11-8.php 文件 ， 其 结果 如 图 11.8 所 示 。 由 于 此 时 并 没有 名 为 style 
任何 样式 。 


单 击 “ 风 格 1” 链接 后 ，11-8.php 将 注册 Cookie 值 为 1 的 变量 style。 此 时 网 页 的 效果 将 会 如 图 11.9 


所 示 。 
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11.8. 首次 运行 11-8.php 文件 时 的 效果 图 11.9 使 用 样式 1 的 效果 


由 于 此 时 已 经 有 了 名 为 style 值 为 1 的 Cookie 变量 ， 所 以 此 时 使 用 样式 1。 结 果 如 图 11.9 所 示 。 


同 理 分 别 单 击 “ 风 格 2”、“ 风 格 3” 链 接 ， 都 会 采用 相应 的 样式 文件 。 其 执行 结果 分 别 如 图 11.10、 
图 11.11 所 示 。 
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INO RAD EEV HRO FONS v J 
用 cookie 实 现 改 变 网 站 风格 用 cookie 实 现 改 变 网 站 风格 
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图 11.10 使 用 样式 2 的 效果 图 11.11 使 用 样式 3 的 效果 


如 果 单 击 “ 无 样式 ”链接 ， 由 于 没有 参数 style, HL 11-9.php 中 的 setcookie 一 句 的 第 2 个 参数 为 
室 ， 此 时 即 为 中 止 使 用 Cookie 变量 style。 即 此 时 的 style 无 效 。 所 以 返回 的 结果 是 同 第 一 次 打开 时 一 
样 的 效果 。 

至 此 使 用 Cookie 实现 网 站 风格 转变 的 实例 就 为 读者 介绍 完了 。 


11.3 本 章 小 结 


这 一 章 为 读者 介绍 了 PHP 中 的 两 种 存储 用 户 信息 的 机 制 ，Session 和 Cookie。 通 过 本 章 的 学 习 ， 
会 使 读者 对 如 何 使 用 这 两 种 方式 存储 用 户 信息 有 一 个 比较 深刻 的 认识 。 其实 不 管 是 采用 Session 作为 存 
储 载 体 还 是 采用 Cookie 作为 存储 的 载体 ， 关 键 要 看 怎么 用 。 二 者 各 有 特点 ， 有 时 ， 也 可 以 把 二 者 结合 
起 来 使 用 ， 取 长 补 短 。 使 自己 用 PHP 编写 的 Web 程序 更 稳定 ， 更 友好 ， 才 是 学 习 的 目的 。 
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正则 表达 式 在 PHP 编程 中 有 着 相当 广泛 的 应 用 ， 它 可 以 实现 对 特定 内 容 的 查找 、 
替换 。 本 章 将 带领 读者 来 学 习 PHP 中 的 正则 表达 式 。 本 章 内 容 包 括 : 什么 是 正则 表达 
式 、 如 何 使 用 模式 匹配 、 正 则 表达 式 语法 、PHP 中 的 正则 表达 式 函 数 、 正 则 表达 式 使 
用 实例 等 。 通 过 本 章 的 学 习 会 使 读者 揭 去 正则 表达 式 那 神秘 的 面纱 ， 一 睹 它 的 风采 。 
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12.1 关于 正则 表达 式 


这 一 节 将 介绍 关于 正则 表达 式 的 基础 性 问题 ， 让 读者 了 解 究 竞 什么 是 正则 表达 式 、 正 则 表达 式 由 
什么 元 素 组 成 、 如 何 使 用 正则 表达 式 等 。 通 过 本 节 学 习 ， 将 会 使 读者 对 正则 表达 式 有 一 个 比较 全 面 的 
了 解 。 


12.1.1 什么 是 正则 表达 式 


简单 的 说 ， 正 则 表达 式 就 是 一 个 字符 构成 的 串 ， 它 定义 了 一 个 用 来 搜索 匹配 字符 串 的 模式 。 它 的 
作用 是 实现 用 正则 表达 式 模式 对 一 个 字符 串 中 特定 的 字符 或 字符 集合 进行 查找 与 替换 。 正 则 表达 式 由 
一 些 普通 字符 和 一 些 元 字符 (metacharacters) 组 成 ， 它 包含 一 个 正则 表达 式 模式 。 正 则 表达 式 中 普 i 
字符 包括 大 小 写 的 字母 和 数字 ， 大 多 数字 字符 在 模式 中 表示 它们 自身 并 匹配 目标 中 相应 的 字符 。 而 元 
字符 则 具有 特殊 的 含义 ， 后 面 会 给 予 解释 。 

例如 ， 判 断 邮 政 编码 是 否 合法 的 正则 表达 式 是 像 下 面 这样 的 内 容 : 

ereg("^([0-9}{6})(-[0-9}{(5})?$") 

其 中 的 “0-9”、“6”、“0-9”、“5” 为 普通 字符 ， 而 里 面 的 “^”、“[]”、“?”、“$” 等 为 
元 字符 。 

正则 表达 式 的 优势 在 于 其 能 够 在 模式 中 包含 选择 和 循环 。 它 们 通过 使 用 元 字符 来 编码 在 模式 中 ， 
元 字符 不 代表 其 自身 ， 它 们 用 一 些 特殊 的 方式 来 解析 。 

有 两 组 不 同 的 元 字符 : 一 种 是 模式 中 除了 方 括号 内 的 都 能 被 识别 ， 另 一 种 是 在 方 括号 内 的 被 识别 。 
下 面 分 别 给 读者 作 介绍 。 

方 括号 之 外 的 元 字符 有 以 下 内 容 ， 如 表 12.1 所 示 。 

R121 正则 表达 式 中 的 元 字符 列表 
| 用 在 方 括号 内 /外 | 作 用 
外 
外 
外 
外 
外 
外 
外 
外 
外 
外 
外 
外 


有 数 种 用 途 的 通用 转 义 符 
匹配 字符 串 的 开始 或 在 多 行 模式 下 行 的 开头 ， 即 紧 随 在 换行 符 之 后 ) 
匹配 字符 串 的 结尾 或 在 多 行 模式 下 行 的 结尾 ， 即 紧 随 在 换行 符 之 前 ) 
匹配 除了 换行 符 外 的 任意 一 个 字符 默认 情况 下 ) 
[ 字符 类 定义 开始 
] 字符 类 定义 结束 
| 开始 一 个 多 选 一 的 分 支 
子 模式 开始 


子 模式 结束 


? 扩展 “(” 的 含义 ， 也 是 0 或 1 数量 限定 符 ， 以 及 数量 限定 符 最 小 值 
匹配 0 个 或 多 个 的 数量 限定 符 
十 匹配 1 个 或 多 个 的 数量 限定 符 
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续 表 
用 在 方 括号 内 /外 作 用 
最 少 /最 多 数量 限定 开始 
最 少 /最 多 数量 限定 结束 
通用 转 义 字符 
排除 字符 类 〈 逻 辑 非 )， 但 仅 当 其 为 第 一 个 字符 时 有 效 
指出 字符 范围 
结束 字符 类 


Al 
>l- H j fe 
a 


表 12.1 中 列 出 的 模式 在 方 括号 内 使 用 的 部 分 称 为 “字符 类 ”。 

在 以 上 介绍 的 儿 种 元 字符 中 ， 反 和 斜 线 是 一 类 特殊 的 字符 ， 反 斜 线 字符 有 3 种 用 途 。 

第 1 个 用 途 就 是 在 它 后 面 跟 上 非 字母 或 数字 的 特殊 符号 来 代替 这 些 特殊 符号 本 身 。 此 种 将 反 斜 线 
用 作 转 义 字符 的 用 法 适用 于 以 上 两 种 情况 。 即 不 论 是 方 插 号 之 内 还 是 方 括号 之 外 都 适用 。 如 要 匹配 一 
个 “*” 字 符 ， 则 在 模式 中 用 “\*”。 这 适用 于 无 论 下 一 个 字符 是 否 会 被 当 作 元 字符 来 解释 ， 因 此 在 非 
字母 数字 字符 之 前 加 上 一 个 “\” 来 指明 该 字符 代表 其 本 身 总 是 安全 的 。 尤 其 是 ， 如 果 要 [匹配 一 个 反 斜 
R, 用 “\”。 

第 2 个 作用 是 提供 了 一 种 在 模式 中 以 可 见方 式 去 编码 不 可 打印 字符 的 方法 。 并 没有 不 可 打印 字符 
出 现 的 限制 ， 除 了 代表 模式 结束 的 二 进 制 零 以 外 。 用 文本 编辑 器 来 准备 模式 的 时 候 ， 通 常用 以 下 的 转 
义 序 列 来 表示 那些 二 进 制 字符 更 容易 一 些 ， 详 见 表 12.2。 


R122 反 斜 线 通 常用 到 的 转 义 序列 所 表示 的 二 进 制 字符 列表 


转 义 字符 所 表示 的 二 进 制 字符 
la alarm， 即 BEL 字 符 (0507) 
\cx “control-x”， 其 中 x 是 任意 字符 
\e escape (0x1B) 
¥ 换 页 符 formfeed (0x0C) 
\n 换行 符 newline (0x0A) 
yi 回 车 符 carriage retum (0x0D) 
\t 制 表 符 tab (0x09) 
\xhh 十 六 进 制 代码 为 hh 的 字符 
\ddd 八进制 代码 为 ddd 的 字符 ， 或 backreference 
\040 另 一 种 表示 空格 的 方法 
\40 同上 ， 如 果 之 前 捕获 的 子 模式 少 于 40 个 的 话 
V 总 是 一 个 逆向 引 月 
MI 可 能 是 个 逆向 引用 ， 或 者 是 制 表 符 tab 
W11 总 是 表示 制 表 符 tab 
10113 表示 制 表 符 tab 后 面 跟着 一 个 字符 “3” 
\113 表示 八进制 代码 为 113 的 字符 〈 因 为 不 能 超过 99 个 逆向 引用 ) 
377 表示 一 个 所 有 的 比特 都 是 1 的 字 节 
\81 要 么 是 一 个 逆向 引用 ， 要 么 是 一 个 二 进 制 的 零 后 面 跟着 两 个 字符 “8” 和 “1? 
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注意 八进制 值 的 100 或 大 于 100 的 值 之 前 不 能 以 零 打 头 ， 因 为 不 会 读 取 〈 反 和 斜 线 后 ) 超过 3 个 八 
进 制 数 字 。 

所 有 的 定义 了 一 个 单一 字 节 的 序列 可 以 用 于 字符 类 之 中 或 之 外 。 此 外 ， 在 字符 类 之 中 ， 序 列 “\b” 
被 解释 为 反 斜 线 字符 〈0x08) ， 而 在 字符 类 之 外 有 不 同 含义 见 下 面 ) 。 

反 斜 线 的 第 3 个 用 法 是 指定 通用 字符 类 型 。 
\d: 任 一 十 进 制 数 字 。 
\D: 任 一 非 十 进 制 数 的 字符 。 
\s: 任 一 空白 字符 。 
\S: 任 一 非 空白 字符 。 
Ww: 任 一 “ 字 ” 的 字符 。 
W: 任 一 “ 非 字 ”的 字符 

反 和 斜 线 的 第 4 个 用 法 是 某 些 简单 的 断言 。 断 言 是 指 在 一 个 匹配 中 的 特定 位 置 必须 达到 的 条 件 ， 并 
不 会 消耗 目标 字符 串 中 的 任何 字符 。 反 和 斜 线 的 断言 如 下 。 
: 字 分 界线 。 
DO \B: 非 字 分 界线 。 
O \A: 目标 的 开头 〈 独 立 于 多 行 模式 ) 。 
O \Z: 目标 的 结尾 或 位 于 结尾 的 换行 符 前 〈 独 立 于 多 行 模式 ) 。 
口 \z: 目标 的 结尾 〈 独 立 于 多 行 模式 ) 。 
口 
这 


DOOOODO 


口 
所 


\G: 目标 中 的 第 1 个 匹配 位 置 。 
些 断 言 可 能 不 能 出 现在 字符 类 中 (但 是 注意 wb" 有 不 同 的 含义 , 在 字符 类 之 中 也 就 是 反 斜 线 字符 ) 。 


12.1.2 ”如 何 使 用 模式 匹配 


12.1.1 小 节 为 读者 介绍 了 什么 是 正则 表达 式 , 及 表达 式 中 的 元 字符 。 这 一 小 节 就 来 介绍 如 何 使 用 匹 
配 模式 。 模 式 是 正规 表达 式 最 基本 的 元 素 。 它 们 是 一 组 描述 字符 串 特 征 的 字符 。 模 式 可 以 很 简单 ， 由 
普通 的 字符 串 组 成 ， 也 可 以 非常 复杂 ， 往 往 用 特殊 的 字符 表示 一 个 范围 内 的 字符 重复 出 现 ， 或 表示 上 
下 文 。 

在 最 简单 的 情况 下 ， 一 个 正则 表达 式 看 上 去 就 是 一 个 普通 的 查找 串 。 如 正则 表达 式 “testing” 中 没 
有 包含 任何 元 字符 ， 它 可 以 匹配 “testing” 和 “123testing” 等 字符 串 ， 但 是 不 能 匹配 “Testing”。 下 
面 详细 为 读者 介绍 如 何 使 用 模式 匹配 。 

1. 元 字符 “^”、“$” 的 使 用 

首先 ， 介 绍 两 个 特别 的 元 字符 ，“^” 和 “$”。 上 面 说 过 它们 是 分 别 用 来 匹配 字符 串 的 开始 和 结 
束 ， 以 下 分 别 举例 说 明 。 

“AThe” 


匹配 以 The 开头 的 字符 串 。 
“of despair$” 
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匹配 以 of despair 结尾 的 字符 串 。 
«nabc$” 
匹配 以 abc 开头 和 以 abc 结尾 的 字符 串 〈 实 际 上 ， 只 有 abe 与 之 匹配 ) 。 
“notice” 
匹配 包含 notice 的 字符 串 。 
从 上 面 3 个 例子 中 可 以 了 解 到 ， 如 果 没 有 用 到 上 面 的 两 个 元 字符 (最 后 一 个 例子 ) ， 就 是 说 模式 
(正则 表达 式 ) 可 以 出 现在 被 检验 字符 串 的 任何 地 方 ， 因 为 没有 把 它 锁 定 到 两 边 。 
2, 元 字符 “yn 9 w+” F ag» 的 使 用 
和 “?” 用 来 表示 一 个 字符 可 以 出 现 的 次 数 或 者 顺序 。 这 3 个 字符 分 别 表示 : 


元 字符 “*”，“+”， 
0 Mep 1 次 或 者 多 次 ; 0 次 或 者 1 次 。 下 面 给 出 几 个 例子 来 说 明 这 3 个 元 字符 是 如 何 匹配 字符 的 。 
“ab” 
匹配 字符 串 a 和 0 个 或 者 更 多 b 组 成 的 字符 串 。 如 “a”、“ab”、“abbb” 等 。 
“abt” 
和 上 面 一 样 ， 但 最 少 有 一 个 b。 如 “ab”、“abbb” 等 。 
“ab?” 


匹配 0 个 或 者 一 个 b。 只 有 两 种 可 能 “a”、 “ab”。 
f 综合 使 用 uan NN BP aan 、 “2 、 
下 面 把 以 上 两 种 模式 中 的 5 个 字符 综合 起 来 举 儿 个 例子 。 
“a?b+$” 
匹配 以 一 个 或 者 0 个 a 再 加 上 一 个 以 上 的 b 结尾 的 字符 串 。 如 “b”、“ab”、“abb”、“abbb” 等 。 

“Aa*b?a$’” 

匹配 以 0 个 或 者 多 个 a 开头 再 加 上 0 个 或 者 1 个 b 再 以 a 结尾 的 字符 串 。 如 “a”、“aa”、“abaaa”、 
“aabaa” 等 。 

4. 元 字符 “{”、“}” 的 使 用 

上 面 讲 了 “{”、“}” 分 别 是 数量 限定 符 开始 和 结束 的 标记 ， 所 以 也 可 以 在 大 插 号 里 面 加 上 数字 
来 限制 字符 出 现 的 个 数 。 如 : 

“ab{2}” 

匹配 一 个 a 后 面 跟 两 个 b (一 个 也 不 能 少 ) 。 如 : “abb” o 

«ab(2}” 

两 个 或 者 更 多 个 “b”〔 即 : 最 少 更 两 个 b) 。 如 “abb”、“abbbb” 等 。 

“ab{3,5}” 
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a 后 面 跟 3~5 个 b ( 仅 有 3、4、5 个 3 种 情况 ) 。 如 “abbb”、“abbbb”、“abbbbb”。 

通过 上 面 的 例子 ， 读 者 能 够 发 现 只 能 使 用 “{0,2}”， 而 不 能 使 用 “{,2}”。 同 样 ，“*”、 “+” 
和 “?” 分 别 和 以 下 3 个 范围 标注 是 一 样 的 ，“{0,}”、“{1,}” 和 “1{0,1}”。 

5. 元 字符 “(”、“)” 的 使 用 

介绍 了 大 括号 ， 再 来 介绍 小 括号 。 

现在 把 一 定数 量 的 字符 放 到 小 括号 里 。 比 如 : 

“a(bc)*” 

匹配 a 后 面 跟 0 个 或 者 1 个 “bc”。 如 “a”、“abc” (只 有 此 两 种 情况 ) 。 

“a(bc}{1,5}” 

匹配 a 后 面 跟 1 个 到 $ 个 “bc”。 如 “abc”、“abc”、“abcbc”、“abcbc” 等 。 

6. 元 字符 “|” 的 使 用 

还 有 一 个 字符 “ | ”， 相 当 于 OR (或 ) 操作 。 如 : 

“hi | hello” 

匹配 含有 “hi” 或 者 “hello” 的 字符 串 。 

“(b | cd)ef” 

匹配 含有 “bef” 或 者 “cdef” 的 字符 串 。 

“(a | bj*c” 

匹配 含有 这 样 0 到 多 个 (包括 0 个 ) a 或 b， 后 面 跟 一 个 c 的 字符 串 。 

7. 元 字符 “.” 的 使 用 

下 面 介 绍 “.” 符 号 。 一 个 点 (.) 可 以 代表 所 有 的 单一 字符 。 如 : 

“a.[0-9]” 

匹配 一 个 a 跟 一 个 字符 再 跟 一 个 数字 的 字符 串 。 

“Aa.{3}$” 

匹配 以 a 开头 3 个 任意 字符 结尾 。 

8. 元 字符 “[”、“]” 的 使 用 

“[]” 中 括号 括 住 的 部 分 只 匹配 单一 字符 。 

“Tab)” 

匹配 单个 的 a 或 者 b (和 “a |b” 一 样 ) 。 

“lady” 

匹配 “a” 到 “d” 的 单个 字符 (和 “a |b| c|d” 还 有 “[abcd]j” 效 果 一 样 ) 。 

“nja-zA-Z]” 


第 12 章 PHP 中 正则 表达 式 的 使 用 183 


匹配 以 字母 开头 的 字符 串 。 
“[0-9]%” 
匹配 含有 形 如 “x9%” 的 字符 串 。 
“,[a-zA-Z0-9]$” 

匹配 以 逗号 在 加 一 个 数字 或 字母 结尾 的 字符 串 。 

9， 中 括号 内 的 元 字符 “^” 的 使 用 

具体 使 用 时 也 可 以 把 不 想 要 得 字符 列 在 中 括号 里 ， 只 需要 在 中 括号 里 面 使 用 “^” 作 为 开头 。 即 中 
括号 里 面 的 “^” 符 号 表示 逻辑 非 。 

“9%[Aa-zA-Z]%?” 

匹配 两 个 百 分 号 中 间 含 有 一 个 非 字 母 的 字符 串 。 如 “%1%”、“%5%” 等 。 

正则 表达 式 中 匹配 模式 的 使 用 ， 这 一 节 就 介绍 完了 。12.2 节 将 为 读者 介绍 PHP 中 的 正则 表达 式 相 
关 函 数 。 


12.2 POSIX 扩展 的 正则 表达 式 函 数 


12.1 节 为 读者 介绍 了 PHP 中 的 匹配 模式 ,但 是 光 有 模式 是 不 能 做 事情 的 ， 必 须 得 有 函数 与 之 一 起 
工作 才能 起 作用 。 所 以 ， 这 一 节 就 来 介绍 PHP 中 的 正则 表达 式 函 数 。PHP 支持 两 种 模式 的 正则 表达 式 
函数 ， 即 PHP 中 有 两 类 不 同 的 正则 表达 式 函 数 。 一 类 是 比较 常用 的 POSIX (Portable Operating System 
Interface 可 移植 操作 系统 接口 ) 扩展 的 正则 表达 式 函 数 ， 另 一 类 是 Perl 兼容 的 正则 表达 式 函 数 。 两 组 
函数 功能 大 同 小 异 ， 但 函数 名 称 及 使 用 方法 却 不 相同 。 下 面 分 别 为 读者 作 讲 解 。 


12.2.1 替换 字符 串 


string ereg_replace(string pattern, string replacement, string string)。 正 则 表达 式 替 换 函 数 。 此 函数 在 
string 中 扫描 与 pattem 匹配 的 部 分 ， 并 将 其 替换 为 replacement。 返 回 替 换 后 的 字符 串 。 如 果 没 有 可 供 
替换 的 匹配 项 则 会 返回 原 字 符 串 。 

下 面 举 两 个 简单 的 例子 来 说 明 此 函数 是 如 何 使 用 的 。 

<html> 

<head> 


<title>ereg_replace() 函 数 使 用 实例 1</title> 
</head> 


$string1="abcacbcbaaab"; /定义 字符 串 变量 
$string2=ereg_replace("a","b",$string1); // 对 字符 串 进行 替换 操作 
echo "string1 的 内 容 为 :"; 

echo $string1; /输出 原 字符 串 内 容 
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echo "<p>"; 
echo "经 过 ereg_replace 处 理 〈 将 a 替换 为 b) 过 的 内 容 为 : "; 


echo $string2; /| 输出 处 理 过 之 后 的 内 容 


</body> 
</html> 


上 面 的 例子 只 是 使 用 了 简单 的 查找 替换 ， 并 没有 用 到 正则 表达 式 模式 。 只 是 通过 该 例子 先 来 了 解 


一 下 ereg_replace() 函 数 是 如 何 起 作用 的 。 保存 以 上 代码 为 “12-1.php”。 在 PHP 执行 环境 中 运行 该 PHP 
文件 ， 其 执行 结果 将 会 如 图 12.1 所 示 。 
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string1 的 内 容 为 ，abcacbcbaaab zi 
经 dereg_ replace 处 理 (将 a 替换 为 b) 过 的 内 容 为 ， 
bbebebebbbbb 

2 
EE [ml ml ml ml Er yA 


图 12.1 ereg_replace() 函 数 使 用 实例 1 执行 结果 


通过 上 例 及 执行 结果 可 见 ， 经 过 ereg_replace0 函 数 的 处 理 ， 字 符 串 $stringl 中 所 有 为 “a” 的 字符 
全 被 替换 成 了 “b”。 实 现 了 替换 字符 串 特定 内 容 的 目的 。 

下 面 再 举 一 个 稍微 复杂 一 点 的 例子 。 这 一 次 要 替换 的 内 容 是 包含 有 正则 表达 式 模式 的 内 容 。 具 体 
内 容 参 看 以 下 代码 : 


<html> 

<head> 

<title>ereg_replace() 函 数 使 用 实例 2</title> 

</head> 

<body> 

<? 

$string1="abcdacdbcbadaab"; /定义 字符 串 变 量 
$string2=ereg_replace("[a-b]","c",$string1); // 对 字符 串 进行 替换 操作 
echo "string1 的 内 容 为 :"; 

echo $string1; /| 输出 原 字符 串 内 容 
echo "<p>"; 

echo "经 过 ereg_replace 处 理 〈 将 a 和 b 替换 为 c) 过 的 内 容 为 : "; 

echo "<p>"; 

echo $string2; /输出 处 理 过 之 后 的 内 容 
?> 

</body> 

</html> 


保存 以 上 代码 为 “12-2.php” 文 件 。 然 后 在 PHP 执行 环境 下 执行 该 文件 ， 执 行 结果 如 图 12.2 所 示 。 


上 面 的 例子 就 用 到 了 正则 表达 式 模式 ， 实 现 的 功能 是 把 字符 串 Sstringl 中 所 有 的 a 和 b BHR co 
经 过 这 样 的 处 理 ， 字 符 串 中 只 有 c 和 d 了 注意 观察 Sstingl 内 容 与 上 例 的 不 同 之 处 ) 。 
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Ferez replace 0 函 致 作用 实 讽 2 -WiCeeSAEE Tater loi 
| 文件 四 ao SEV kaw TA 和 WD KA 


string1 的 内 容 为 : abcdacdbcbadaab 
Biereg replace (HAMEEN) 过 的 内 容 为 : 


ecedccdccccdccc 


到 
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图 12.2 ereg_replace(O) 函 数 使 用 实例 2 执行 结果 


12.2.2 ”匹配 字符 串 


bool ereg(string pattern,string string[,array regs]) 函 数 对 string 字符 串 进 行 查找 。 如 果 在 string 中 找到 
pattern 模式 的 匹配 ， 则 返回 True， 如 果 没 有 找到 匹配 或 出 错 则 返回 False。 

注意 此 函数 与 Perl 兼容 正则 表达 式 语法 的 preg_match() 函 数 具有 相同 的 功能 。 通 常 使 用 preg_matchO) 
函数 是 比 ereg() 函 数 更 快 的 蔡 代 方案 。 

下 面 举 儿 个 简单 的 例子 来 说 明 ereg() 函 数 是 如 何 实现 字符 的 匹配 操作 的 。 

<html> 

<head> 


<title>ereg() 函 数 使 用 实例 1</title> 
</head> 


$string1="abcde"; 
$string2="bbcde"; 

echo "string1 的 内 容 为 : "; 
echo $string1; 

echo "<p>"; 

echo "string2 的 内 容 为 : "; 
echo $string2; 

echo "<p>"; 

function panduan($s) 


if(ereg("a",$s)) echo "包含 a"; 
else echo "不 包含 a"; 


} 

echo "string1 中 包含 小 写字 母 a 吗 ? "; 
panduan($string1); 

echo "<p>"; 

echo "string2 中 包含 小 写字 母 a 吗 ? "; 
panduan($string2); 

?> 

</body> 

</html> 


上 面 的 例子 中 ， 只 是 进行 了 简单 的 判断 ， 


// 定 义 变量 $string1 
// 定 义 变量 $string2 


/输出 内 容 


/输出 内 容 


/在 ereg() 函 数 的 基础 上 自 定义 一 个 函数 


/根据 ereg() 返 回 结果 输出 不 同 内 容 


/调用 自 定义 函数 进行 判断 


// 调 用 自 定义 函数 进行 判断 


即 在 一 个 字符 串 中 有 没有 包含 另 一 个 字符 。 其 中 并 没有 
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用 到 正则 表达 式 模式 。 保 存 以 上 代码 为 “12-3.php”。 


图 12.3 所 示 。 
从 上 例 及 执行 结果 可 以 发 现 ， 通 过 在 ereg0 函 
kaa aaa 正确 的 输出 
一 个 字符 串 中 是 否 含有 另 一 个 字符 〈 串 ) 。 下 
we 个 例子 ， 使 用 正则 表达 式 模式 对 字符 串 
进行 是 否 匹 配 的 判断 。 具 体内 容 参 看 以 下 代码 : 
<html> 
<head> 


<title>ereg() 函 数 使 用 实例 2</title> 
</head> 


$string1="abcde"; 
$string2="ABCD"; 

echo "string1 的 内 容 为 :"; 
echo $string1; 

echo "<p>"; 

echo "string2 的 内 容 为 :"; 
echo $string2; 

echo "<p>"; 

function panduan ($s) 


if(ereg("[a-z]",$s)) echo "包含 小 写字 母 "; 
else echo "不 包含 小 写字 母 "; 


} 

echo "string? 中 包含 小 写字 母 吗 ? "; 
panduan($string1); 

echo "<p>"; 

echo "string2 中 包含 小 写字 母 吗 ? "; 
panduan($string2); 

?> 

</body> 

</html> 


保存 以 上 代码 为 “12-4.php” 
所 示 。 

此 次 自 定义 的 函数 在 使 用 ereg() 函 数 时 ,调用 
了 正则 表达 式 模式 ， 即 [az] (所 有 的 小 写字 母 ) 。 
对 两 个 字符 串 中 是 否 含有 小 写字 母 进行 判断 。 从 
执行 结果 中 也 可 以 了 解 到 ， 由 于 $stringl 中 包含 了 
小 写字 母 ， 所 以 ereg(0) 函 数 返回 True; 而 $string2 
中 没有 包含 小 写字 母 (其 中 全 为 大 写字 母 ) , ereg() 
函数 返回 了 False。 通 过 该 实例 也 可 以 发 现 此 函数 


。 然 后 在 PHP 执行 环境 中 运行 该 
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行 该 文件 ， 


执行 结果 如 


string] 的 内 容 为 ，abcde 
string2 的 内 容 为: 
string1 中 包含 小 写字 母 a 虽 ? 包含 a 

atring2 中 包含 小 写字 母 a 吗 ? 不 包含 a 
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图 12.3 eregO 函 数 使 用 实例 1 执行 结果 


/定义 变量 $string1 
/定义 变量 $string2 


/输出 内 容 


/输出 内 容 


/在 ereg() 函 数 的 基础 上 自 定义 一 个 函数 


/根据 ereg() 返 回 结果 输出 不 同 内 容 


// 调 用 自 定义 函数 进行 判断 


/调用 自 定义 函数 进行 判断 


该 文件 ， 其 执行 


结果 将 会 如 图 12.4 


汪 .rezO 函 数 使 用 实例 2 -Mi nlor: alol xi 
ED CTE- 四 ) TRO IRW ahw | 
string] 的 内 容 为 ，abcde 加 
string2 的 内 容 为 ，ABCD 

stringl 中 包含 小 写字 母 码 1 和 包含 小 写字 母 
tring? 中 包含 小 写字 母 吗 1 不 包含 小 写字 母 

am COCO Ee 3 


图 12.4 eregO) 函 数 使 用 实例 2 执行 结果 
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是 如 何 起 作用 的 。 
12.2.3 ”替换 字符 串 〈 忽 略 大 小 写 ) 


string eregi replace(string pattern,string replacement,string string)。 不 区 分 大 小 写 的 正则 表达 式 蔡 换 。 
此 函数 与 ereg_replace(0) 函 数 有 一 样 的 功能 ， 除 了 在 替换 字母 字符 时 忽略 字母 的 大 小 写 。 
下 面 通过 一 个 例子 来 说 明 此 函数 与 函数 ereg_repalce0 的 区 别 之 处 。 具 体内 容 参 看 以 下 代码 : 


<html> 

<head> 
<title>eregi_replace() 函 数 使 用 实例 </title> 
</head> 


$string1="abcacbcbAAAb"; /定义 字符 串 变 量 
$string2=eregi_replace("a","b",$string1); // 对 字符 串 进行 替换 操作 
echo "string1 的 内 容 为 : “ 

echo $string1; /| 输出 原 字 符 串 内 容 
echo "<p>"; 

echo "经 过 eregi_replace 处 理 〈 将 a 替换 为 b) 过 的 内 容 为 : " 

echo "<p>"; 

echo $string2; /| 输 出 处 理 过 之 后 的 内 容 
?> 

</body> 

</html> 


这 个 例子 只 是 对 12-1.php 进行 了 简单 的 修改 。 其 中 的 改动 一 个 是 把 函数 ereg_replace() 蔡 换 为 函数 
eregi_replace0， 另 一 个 也 相应 的 把 $Sstringl 内 容 进行 了 调整 。 保 存 以 上 代码 为 “12-5.php”。 在 PHP 执 
行 环 境 下 执行 该 文件 ,其 执行 结果 将 会 如 图 12.5 = 


所 示 。 9 
从 图 125 中 可 以 了 解 ， 由 于 忽略 ý 字母 字 ee abcacbcbAAAb | 

符 的 大 小 写 ; 所 以 大 写字 母 Ä 也 被 替换 成 T 小 DPA 《将 :替换 为 b) 过 的 内 容 为 ， 

写字 母 b。 由 于 该 函数 与 ereg_replace() 函 数 功能 kaza AA 


大 致 相似 , 所 以 就 不 再 多 举 实例 。 有 兴趣 的 读者 
可 以 把 12-2.php 文件 作 上 述 修改 以 查看 二 者 的 
区 别 。 


图 12.5 eregi_replace() 函 数 使 用 实例 执行 结果 


12.2.4 ”匹配 字符 串 (忽略 大 小 写 ) 


bool eregi(string pattern,string string[,array regs]) 不 区 分 大 小 写 的 正则 表达 式 匹配 。 此 函数 与 ereg() 
函数 也 有 一 样 的 功能 ， 不 同 的 是 在 进行 正则 表达 式 的 匹配 字母 字符 时 也 忽略 字母 的 大 小 写 。 

接 下 来 仍然 通过 一 个 例子 来 说 明 该 函数 的 使 用 。 通 过 例子 读者 就 会 发 现 该 函数 与 ereg() 函 数 的 
区 别 。 
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<html> 

<head> 

<title>eregi() 函 数 使 用 实例 </title> 
</head> 


$string1="abcde"; 
$string2="ABCD"; 

echo "string1 的 内 容 为 : " 
echo $string1; 

echo "<p>"; 

echo "string2 的 内 容 为 : "; 
echo $string2; 

echo "<p>"; 

function panduan($s) 

{ 


if(eregi("[a-z]",$s)) echo "包含 小 写字 母 "; 


else echo "不 包含 小 写字 母 "; 


} 

echo "string1 中 包含 小 写字 母 吗 ? "; 
panduan($string1); 

echo "<p>"; 

echo "string2 中 包含 小 写字 母 吗 ? " 
panduan($string2); 

?> 

</body> 

</html> 


/定义 变量 $string1 
/定义 变量 $string2 


/输出 内 容 


/输出 内 容 


/在 eregi() 函 数 的 基础 上 自 定义 一 个 函数 


/根据 eregi() 返 回 结果 输出 不 同 内 容 


// 调 用 自 定义 函数 进行 判断 


// 调 用 自 定义 函数 进行 判断 


对 比 以 上 代码 与 12-4.php， 可 以 发 现 此 实例 是 对 12-4.php 进行 的 简单 的 修改 ， 通 过 修改 读者 也 可 


以 发 现 两 个 函数 在 处 理 字母 字符 时 的 区 别 。 保 存 以 上 代码 为 “12-6.php”。 在 PHP 执行 环境 下 运行 该 


文件 ， 其 执行 结果 将 会 如 图 12.6 所 示 。 
查看 图 12.6 执行 结果 ， 肯 定 会 有 些 读者 不 理解 ， 
为 什么 只 包含 大 写字 母 的 字符 串 $string2 会 被 说 成 仿 
有 小 写字 母 呢 ? 因为 这 里 使 用 了 eregi() 函 数 。 因 为 该 
函数 在 进行 匹配 时 是 忽略 字母 字符 的 大 小 写 的 ， 所 以 
才 会 出 现 这 样 的 情况 。 同 时 这 也 提醒 了 用 户 在 进行 大 
小 写字 母 精确 匹配 时 应 该 使 用 ereg() 函 数 , 而 不 能 使 


| 。。c ORPA - Microsoft Taternet Feriaren- | 
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string] 的 内 容 为 ，abcde 
string? 的 内 容 为 ，ABCD 
stringl 中 和 包含 小 写字 和 母 吗 1 包含 小 写字 母 
string2 中 包含 小 写字 母 吗 1 包含 小 写 宁 母 


Eg ml FE 


图 12.6 ”eregi(0) 函 数 使 用 实例 执行 结果 


加 
YA 


eregi() 函 数 。 
12.2.5 ”分割 字符 串 到 数组 


array split(string pattern,string string[,int limitl) 使 用 正则 表达 式 将 字符 串 分 割 到 数组 中 。 该 函数 返回 
一 个 字符 串 数 组 , 数组 的 每 个 元 素 为 string 经 区 分 大 小 写 的 正则 表达 式 pattern 作为 边界 分 割 出 的 子 串 。 
如 果 设 定 了 limit， 则 返回 的 数组 最 多 包含 limit 个 单元 ， 而 其 中 最 后 一 个 单元 包含 了 string 中 剩余 的 所 
有 部 分 。 如 果 出 错 ， 则 split0 返 回 False。 
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另外 ， 使 用 了 Per 兼容 正则 表达 式 语 法 的 preg_split0 函 数 ， 通 常 是 比 split0 函 数 更 快 的 替代 方案 。 


如 果 不 需 要 正则 表达 式 的 威力 ， 则 使 用 
则 表达 式 引擎 的 浪费 。 


数组 操作 函数 中 的 explode() 函 数 ， 会 更 快 。 这 样 就 不 会 招致 正 


下 面 举 两 个 简单 的 例子 ， 使 读者 通过 具体 的 实例 来 理解 split0 函 数 是 如 何 把 字符 串 切 分 为 数组 的 。 


<html> 

<head> 

<title>split() 函 数 使 用 实例 1</title> 
</head> 


$string1="ab:cd:efgh:i"; 

echo "string1 的 内 容 为 : "; 

echo $string1; 

echo "<p>"; 

echo "经 过 split 处 理 过 之 后 的 数组 内 容 为 :"; 
echo "<p>"; 

S$temp=split(":",$string1); 
for($i=0;$i<count($temp);$i++) 


echo "temp[".$i."] 为 :"; 
echo $temp[$i]; 
echo", "; 

} 

?> 

</body> 

</html> 


// 定 义 变量 $string1 
/| 输出 内 容 


// 对 字符 串 进行 split 处 理 
// 通 过 循环 输出 数组 内 容 


保存 以 上 代码 为 “12-7.php”。 然 后 在 PHP 执行 环境 中 执行 该 文件 ， 执 行 结果 如 图 12.7 所 示 。 
从 图 12.7 可 以 了 解 到 ， 经 过 splitO 函 数 的 处 理 ， 
把 原来 的 字符 串 变 量 $string1 按照 “:” 分 割 成 了 数组 。 


从 而 实现 了 把 字符 串 切 分 为 数组 的 功能 。 


但 是 ，12-7.php 只 是 实现 了 以 普通 字符 作为 分 割 
标准 。 那 么 ， 如 果 以 正则 表达 式 模 式 作为 分 割 标准 又 
会 怎么 样 呢 ? 下 面 继续 通过 一 个 实例 来 说 明 ， 以 正则 


表达 式 模式 作为 标准 时 ，splitO 函 数 是 如 何 起 作 
具体 内 容 请 参看 以 下 代码 : 

<html> 

<head> 


<title>split() 函 数 使 用 实例 2</title> 


</head> 


$string1="ab123cd2efgh890i"; 
echo "string1 的 内 容 为 :"; 


的 。 
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ring1 的 内 容 为 ，ab: cd:efeh:i 
经 过 split 处 理 过 之 后 的 数组 内 容 为， 


teamp[0] 为 ，ab，temp[1] 为 ，cd，temp[2] 为 ，efeh, 
temp[3] 为 ，i， 


E] 
SEZ taf [ D O tent yA 
图 12.7 split0 函 数 使 用 实例 1 执行 结果 
// 定 义 变量 $string1 
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echo $string1; // 输 出 内 容 

echo "<p>"; 

echo "经 过 split 处 理 过 之 后 的 数组 内 容 为 :"; 

echo "<p>"; 

S$temp=split("[0-9]+",$string1); // 对 字符 串 进行 split 处 理 
for($i=0;$i<count($temp);$i++) // 通 过 循环 输出 数组 内 容 
{ 


echo "temp[".$i."] 为 : "; 
echo $temp[$i]; 
echo", "; 

F 

?> 

</body> 

</html> 


保存 以 上 代码 为 “12-8.php”。 然 后 在 PHP 执行 环境 下 执行 该 文件 ， 其 执行 结果 将 如 图 12.8 
所 示 。 


写 :*1it 0 函数 使 用 实例 > - Nicrosoft Internat Ei alo 
从 以 上 代码 可 以 发 现 12-8.php ai ee me aa ao a L 
处 。12-7.php EMET FA REE Aee AE Wama 


经 过 spli1 外 理 过 之 后 的 数组 内 容 为 ， 


个 字符 > ， 而 12-8.php 对 字符 串 分 割 时 使 用 的 分 害 temp[0] 为 ，ab，temp[1] 为 ，cd，temp [2] 为 ，efeh, 

标准 则 是 一 个 正则 表达 式 模式 “[0.9]j+”， 即 1 到 多 个 | saw g 
数字 ， 也 就 是 用 1 到 多 个 数字 作为 分 割 的 标准 。 而 输出 Ee 
结果 也 证 明了 结果 的 正确 性 。 图 12.8 split() 函 数 使 用 实例 2 执行 结果 


12.2.6 “分割 字符 串 到 数组 〈 忽 略 大 小 写 ) 


array spliti(string pattern,string string[,int limit]) 函 数 实 现 功能 与 函数 split0) 完 全 一 样 ， 只 是 在 对 字符 
串 进 行 分 割 时 忽略 字母 字符 的 大 小 写 。 

由 于 此 函数 与 split() 函 数 功能 相似 ， 唯 一 的 不 同 就 是 在 分 割 时 忽略 了 字母 字符 的 大 小 写 。 所 以 下 面 
就 只 通过 一 个 简单 的 例子 来 说 明 该 函数 是 如 何 使 用 的 。 

<html> 

<head> 

<title>spliti() 函 数 使 用 实例 </title> 


</head> 


$string1="abzcdZefghzi"; // 定 义 变量 $string1 

echo "string1 的 内 容 为 :"; 

echo $string1; // 输 出 内 容 

echo "<p>"; 

echo "经 过 spliti 处 理 过 之 后 的 数组 内 容 为 : "; 

echo "<p>"; 

S$temp=spliti("z",$string1); // 对 字符 串 进行 split 处 理 
for($i=0;$i<count($temp);$i++) // 通 过 循环 输出 数组 内 容 
{ 
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echo "temp[".$i."] 为 : "; 
echo SB 
echo", "; 

3 

?> 

</body> 

</html> 


保存 以 上 代码 为 “12-9.php”， 在 PHP 执行 环境 中 执行 该 文件 ， 执 行 结果 将 会 如 图 12.9 所 示 。 
在 12-9.php 中 ， 使 用 小 写字 母 “z” 来 作为 分 割 


Bali 〇 两 数 使 用 实例 - Wicrosoft Taterset kakosa, 
标准 , 但 是 字符 串 变 量 Sstring 中 既 含 有 小 写字 母 “2” Ne Ee o 
又 有 大 写字 母 “Z”。 如 果 是 使 用 split0 函 数 进行 分 ee 
割 ， 会 只 严格 的 使 用 小 写字 母 ， 返 回 的 数组 只 有 3 Se 国力 ab, tepl, i ali efeh, 
个 元 素 。 由 于 spliti0 函 数 是 忽略 字母 字符 ， 所 以 把 te 加 为 
大 写字 母 也 作为 分 割 标准 ， 这 样 一 来 ， 返 回 的 数组 下 
就 有 4 个 元 素 了 。 图 12.9 spliti0 函 数 使 用 实例 执行 结果 
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string sql_regcase(string string)。 产 生 用 于 不 区 分 大 小 写 的 匹配 的 正则 表达 式 。 此 函数 返回 与 string 
相 匹 配 的 正则 表达 式 ， 忽 略 大 小 写字 母 。 返 回 的 表达 式 是 将 string 中 的 每 个 字母 字符 转换 为 方 括号 表 
达 式 ， 该 方 括号 表达 式 包含 了 该 字母 的 大 小 两 种 形式 。 其 他 非 字 母 字符 保留 不 变 。 
下 面 举 一 个 简单 的 例子 来 说 明 此 函数 是 如 何 使 用 的 。 


<html> 

<head> 

<title>sql_regcase() 函 数 使 用 实例 </title> 
</head> 


Sstring1="ab-zcd!Zefg?hzi"; // 定 义 变量 $string1 
echo "string1 的 内 容 为 :"; 

echo $string1; // 输 出 内 容 

echo "<p>"; 

echo "经 过 sql_regcase 处 理 过 之 后 的 内 容 为 :"; 

echo "<p>"; 

$string2=sql_regcase($string1); // 对 字符 串 进 行 sql_regcase 处 理 
echo $string2; // 输 出 处 理 过 的 结果 
?> 

</body> 

</html> 


保存 以 上 代码 为 “12-10.php”， 在 PHP 执行 环境 下 执行 该 文件 ， 其 执行 结果 将 会 如 图 12.10 所 示 。 
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从 图 12.10 可 以 了 解 到 ， 经 过 sql regcase 处 理 ， 原 来 的 每 个 字母 字符 都 转换 为 
该 方 括号 表达 式 包含 了 该 字母 的 大 小 西 种 形式 。 访 aaa eet MASAI 
函数 使 用 的 场合 就 是 对 包含 字母 规则 的 正则 表达 (aho mao sze mo zao mo Lz] 
式 模式 进行 处 理 , 使 原本 只 支持 大 写 或 者 小 写 的 正 ee 
则 表达 式 模式 ( 字 串 ) 转变 成 不 区 分 大 小 写 的 正则 
表达 式 模式 。 

上 面 的 儿 个 就 是 使 用 POXSI 扩展 的 正则 表达 
式 函 数 。 下 面 来 介绍 使 用 Perl 兼容 模式 的 正则 表达 
式 函数 。 


[Aa] [Bb]-[zz] (Cc) [DA] ! [Zz] [Ee] [F£] [Cs]? [Hh] [Zz] [Ii] H 


[CEs l [| E Fj 


图 12.10 sql_regcase() 函 数 使 用 实例 执行 结果 


12.3 Perl 兼容 的 正则 表达 式 函 数 


PHP 有 两 组 正则 表达 式 函 数 。 在 12.2 节 介绍 POXSI 扩展 的 正则 表达 式 函 数 的 时 候 就 曾 提 到 有 几 个 
可 以 相互 蔡 代 的 函数 。 通 常情 况 下 ， 二 者 在 某 些 函数 功能 上 具有 相似 性 ， 可 以 替代 。 


12.3.1 Per 兼容 正则 表达 式 的 使 用 规范 


使 用 Perl 兼容 正则 表达 式 函 数 的 表达 式 应 被 包含 在 定 界 符 中 ， 如 斜 线 (/) 。 任 何不 是 字母 、 数 字 
或 反 斜 线 O 的 字符 都 可 以 作为 定 界 符 。 如 果 作 为 定 界 符 的 字符 必须 被 用 在 表达 式 本 身 中 ， 则 需要 用 
反 和 斜 线 转 义 。 自 PHP 4.0.4 起 ， 也 可 以 使 用 Perl 风格 的 “()”，“{}”，“[]” 和 “<>” 匹 配 定 界 符 。 
结束 定 界 符 后 可 以 跟 上 不 同 的 修正 符 以 影响 匹配 方式 。 

下 面 列 出 了 当前 在 PCRE 中 可 能 使 用 的 修正 符 。 插 号 中 是 这 些 修 正 符 的 内 部 PCRE 名 。 修 正 符 中 
的 空格 和 换行 被 忽略 ， 其 他 字符 会 导致 错误 。 

1. i(PCRE_CASELESS) 

如 果 设 定 此 修正 符 ， 模 式 中 的 字符 将 同时 匹配 大 小 写字 母 。 

2. m (PCRE MULTILINE) 

默认 情况 下 ，PCRE 将 目标 字符 串 作 为 单一 的 一 “ 行 ” 字符 所 组 成 的 〈 甚 至 其 中 包含 有 换行 符 也 是 
如 此 ) 。“ 行 起 始 ” 元 字符 〈^) 仅仅 匹配 字符 串 的 起 始 ，“ 行 结束 ”元 字符 〈$) 仅仅 匹配 字符 串 的 
结束 ， 或 者 最 后 一 个 字符 是 换行 符 时 它 的 前 面 ( 除 非 设 定 了 DD 修正 符 ) 。 

当 设 定 了 此 修正 符 ，“ 行 起 始 ” 和 “ 行 结束 ”除了 匹配 整个 字符 串 开 头 和 结束 外 ， 还 分 别 匹配 其 
中 的 换行 符 的 之 后 和 之 前 。 这 和 Perl 的 /m 修正 符 是 等 效 的 。 如 果 目 标 字符 串 中 没有 “\n” 字 符 或 者 模 
式 中 没有 ^ 或 $， 则 设 定 此 修正 符 没 有 任何 效果 。 

3. s (PCRE DOTALL) 

如 果 设 定 了 此 修正 符 ， 模 式 中 的 圆 点 元 字符 〈.) 匹配 所 有 的 字符 ， 包 括 换 行 符 。 没 有 此 设 定 的 话 ， 
则 不 包括 换行 符 。 这 和 Perl 的 /s 修正 符 是 等 效 的 。 排 除 字符 类 如 [^a] 总 是 匹配 换行 符 的 , 无 论 是 否 设 定 
了 此 修正 符 。 
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4. x (PCRE EXTENDED) 

如 果 设 定 了 此 修正 符 ， 模 式 中 的 空白 字符 除了 被 转 义 的 或 在 字符 类 中 的 以 外 将 完全 被 忽略 ， 在 未 
转 义 的 字符 类 之 外 的 # 以 及 下 一 个 换行 符 之 间 的 所 有 字符 ， 包 括 两 头 ， 也 都 被 忽略 。 这 和 Perl 的 /x 修正 
符 是 等 效 的 ， 使 得 可 以 在 复杂 的 模式 中 加 入 注释 。 然 而 注意 ， 这 仅 适用 于 数据 字符 。 空 白字 符 可 能 永 
远 不 会 出 现 于 模式 中 的 特殊 字符 序列 。 如 引入 条 件 子 模式 的 序列 (?) 中 间 。 

5. e 

如 果 设 定 了 此 修正 符 ，preg_replace() 在 替换 字符 串 中 对 逆向 引用 作 正 常 的 蔡 换 ， 将 其 作为 PHP 代 
码 求 值 ， 并 用 其 结果 来 替换 所 搜索 的 字符 串 。 只 有 preg_replace() 使 用 此 修正 符 ， 其 他 PCRE 函数 将 
忽略 。 
注意 : 此 修正 符 在 PHP 3 中 不 可 用 。 

6. A (PCRE ANCHORED) 

如 果 设 定 了 此 修正 符 ， 模 式 被 强制 为 “anchored”， 即 强制 仅 从 目标 字符 串 的 开头 开始 匹配 。 此 效 
果 也 可 以 通过 适当 的 模式 本 身 来 实现 (在 Perl 中 实现 的 唯一 方法 ) 。 

7. D (PCRE DOLLAR ENDONLY) 

如 果 设 定 了 此 修正 符 ， 模 式 中 的 美元 元 字符 仅 匹 配 目标 字符 串 的 结尾 。 没 有 此 选项 时 ， 如 果 最 后 
一 个 字符 是 换行 符 的 话 ， 美 元 符号 也 会 匹配 此 字符 之 前 (但 不 会 匹配 任何 其 他 换行 符 之 前 》。 如 果 设 
定 了 m 修正 符 则 忽略 此 选项 。Perl 中 没有 与 其 等 价 的 修正 符 。 

8. S 

当 一 个 模式 将 被 使 用 若干 次 时 ， 为 加 速 匹 配 起 见 值得 先 对 其 进行 分 析 。 如 果 设 定 了 此 修正 符 则 会 
进行 额外 的 分 析 。 目 前 ， 分 析 一 个 模式 仅 对 没有 单一 固定 起 始 字符 的 non-anchored 模式 有 用 。 

9. U (PCRE UNGREEDY) 

此 修正 符 反 转 了 匹配 数量 的 值 使 其 不 是 默认 的 重复 , 而 变 成 在 后 面 跟 上 “?” 才 变 得 重复 。 这 和 Perl 
不 兼容 。 也 可 以 通过 在 模式 之 中 设 定 (?U) 修 正 符 或 者 在 数量 符 之 后 跟 一 个 问号 (如 .*?) 来 启用 此 选项 。 

10. X (PCRE_EXTRA) 

此 修正 符 启用 了 一 个 PCRE 中 与 Perl 不 兼容 的 额外 功能 。 模 式 中 的 任何 反 斜 线 后 面 跟 上 一 个 没有 
特殊 意义 的 字母 将 导致 一 个 错误 ， 从 而 保留 此 组 合 以 备 将 来 扩充 。 默 认 情况 下 ， 和 Perl 一 样 ， 一 个 反 
斜 线 后 面 跟 一 个 没有 特殊 意义 的 字母 被 当成 该 字母 本 身 。 当 前 没有 其 他 特性 受 此 修正 符 控制 。 

11. u (PCRE_UTF8) 

此 修正 符 启 用 了 一 个 PCRE 中 与 Perl 不 兼容 的 额外 功能 .模式 字符 串 被 当成 UTF-8。 本 修正 符 在 Unix 
下 自 PHP 4.1.0 起 可 用 , 在 win32 FA PHP 4.2.3 起 可 用 。 自 PHP 4.3.5 起 开始 检查 模式 的 UTF-8 合法 性 。 


12.3.2 ”返回 匹配 数组 


array preg_grep(string pattem,array input) 返 回 与 模式 匹配 的 数组 元 素 。 返回 的 数组 包括 了 input 数组 
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中 与 给 定 的 pattern 模式 相 匹 配 的 元 素 。 自 PHP 4.0.4 起 ,preg_grep0) 返 回 的 结果 使 用 从 输入 数组 来 的 键 
名 进行 索引 。 如 果 不 希 望 这 样 的 结果 ， 用 array_values() 对 preg_grep() 返 回 的 结果 重新 索引 。 
下 面 通过 一 个 例子 说 明 此 函数 是 如 何 从 数组 中 提取 出 适合 的 模式 匹配 的 。 具体 内 容 参 看 以 下 代码 : 
<html> 
<head> 


<title>preg_grep() 函 数 使 用 实例 </title> 
</head> 


$temp[0]="abc"; /定义 数组 元 素 
$temp[1]=123; 
$temp[2]="us."; 
$temp[3]=5; 
$temp[4]=58; 
$temp[5]="CS"; 
echo "数组 temp 的 内 容 为 :"; 
echo "<P>"; 
for($i=0;$i<count($temp);$i++) // 通 过 循环 输出 数组 内 容 
{ 

echo $temp[$i]; 

echo", "; 
} 
echo "<p>"; 
echo "经 过 preg_grep() 处 理 过 之 后 的 新 数组 为 : "; 
S$temp2=preg_grep("/^(\d)\d*/", $temp); // 使 用 preg_grep 进行 处 理 
/上 式 的 正则 表达 式 模式 中 “//” 为 定 界 符 ， 其 内 容 为 所 有 整数 元 素 
echo "<P>"; 
print_r($temp2); // 通 过 循环 输出 新 数组 内 容 
?> 
</body> 
</html> 


保存 以 上 代码 为 “12-11.php”, 在 PHP 执行 
环境 下 执行 该 文件 ， 其 执行 结果 将 会 如 图 12.11 
遍 示 ， BE ami EA 

从 图 12.11 可 以 发 现 ， 经 过 Preg_grep() 函 数 经 dreg_gre 0 处 理 过 之 后 的 新 数组 为 ， 
的 处 理 ， 提 取出 了 匹配 pattern 正则 表达 式 的 元 a ASAA BTS MSI 
素 ， 组 成 了 一 个 新 的 数组 。 然 而 新 数组 所 使 用 的 a Saa. a 
键 名 ， 依 然 是 原来 数组 的 键 名 。 


ATE 
EE 
E| 


abc, 123, us., 5, 58, CS, 


图 12.11 preg_grep() 函 数 使 用 实例 执行 结果 
12.3.3 全 局 表达 式 匹 配 


int preg_match all(string pattem,string subject,array matches[,int flags]) 函 数 进行 全 局 正则 表达 式 匹 
配 。 在 subject 中 ， 搜 索 所 有 与 pattern 给 出 的 正则 表达 式 匹 配 的 内 容 并 将 结果 以 flags 指定 的 顺序 放 到 
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matches 中 。 搜 索 到 第 1 个 匹配 项 之 后 ， 接 下 来 的 搜索 从 上 一 个 匹配 项 末尾 开始 。 函 数 返 回 整个 模式 匹 
配 的 次 数 〈 可 能 为 零 ) ， 如 果 出 错 返回 Falses 

flags 可 以 是 下 列 标记 的 组 合 (注意 把 PREG_ PATTERN ORDER 和 PREG SET ORDER 合 起 来 用 
没有 意义 ) : PREG_ PATTERN ORDER: 对 结果 排序 使 Smatches[0] 为 全 部 模式 匹配 的 数组 , $matches[1] 
为 第 1 个 括号 中 的 子 模式 所 匹配 的 字符 串 组 成 的 数组 ， 以 此 类 推 。 

下 面 的 一 个 例子 就 说 明 此 函数 是 如 何 使 用 PREG_PATTERN_ORDER 参数 ,并 对 结果 进行 排序 的 。 
具体 内 容 参 看 以 下 代码 : 

<html> 

<head> 


<title>preg_match_all() 函 数 使 用 实例 1</title> 
</head> 


$string="<b>example: </b><div align=left>this is a test</div>"; // 定 义 字 符 串 
S$pattern="|<[^>]+>(.*)</[*>]+>|U"; // 定 义 正则 表达 式 模式 
preg_match_all($pattern,$string,$out, PREG_PATTERN_ORDER); /进行 preg_mathc _all 处 理 
echo $out[O][O]; 

echo", "; 

echo $out[0][1]; 

echo "<p>"; 

echo $out[1][0]; 

echo", "; 


echo $out[1][1]; 
?> 


</body> 
</html> 
保存 以 上 代码 为 “12-12.php”， 在 PHP 执行 环境 下 执行 该 文件 ， 执 行 结 果 如 图 12.12 所 示 。 
先 来 分 析 $patterm 正则 表达 式 模 式 所 表达 


Dre ORAA M ali 
的 含义 。 ETRTIE TREE 到 
zi 

Spattenz "> >) MS >IU": Banda est 
其 中 的 “|”、“|” 为 定 界 符 ， 里面 的 内 容 copione taa iaa apak É 
表示 什么 含义 呢 ? EE E 


第 1 个 “<” 表 示 以 小 于 号 开头 的 内 容 , 后 图 12.12 ”preg_match_all0 函 数 使 用 实例 1 执行 结果 
面 跟 1 个 到 多 个 不 为 “>” 的 字符 加 上 “>” 结 
尾 的 内 容 。 子 模式 中 的 “.*” 表 示 0 到 多 个 任意 字符 。 再 加 上 以 “<” 开 头 的 内 容 后 面 跟 1 个 到 多 个 不 
为 “>” 的 字符 加 上 “>” 符 号 。 模 式 修订 符 “U” 的 含义 是 反 转 了 匹配 数量 的 值 使 其 不 是 默认 的 重复 。 

从 图 12.12 可 以 发 现 , 经 过 加 上 PREG PATTERN ORDER 参数 的 preg_match_all 函数 的 处 理 正确 
地 返回 了 数组 。 

PREG SET ORDER 对 结果 排序 。 使 Smatches[0] 为 第 1 组 匹配 项 的 数组 ，$matches[1] 为 第 2 组 匹 
配 项 的 数组 ， 以 此 类 推 。 

下 面 通过 一 个 的 例子 来 说 明 函数 是 如 何 使 用 PREG_SET_ORDER 对 字符 串 进行 提取 及 排序 的 。 具 


<19% > 


体内 容 参看 以 下 代码 : 


<html> 

<head> 

<title>preg_match_all() 函 数 使 用 实例 2</title> 
</head> 


$string="<b>example: </b><div align=left>this is a test</div>"; 
$pattern="|<[^>]+>(.*)</[^>]+>]U"; 
preg_match_all($pattern,$string,$out, PREG_SET_ORDER); 
echo $out[0}[0]; 

echo", "; 

echo $out[O][1]; 

echo "<p>"; 

echo $out[1][0]; 

echo", "; 

echo $out[1][1]; 

?> 


</body> 
</html> 
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/定义 字符 串 
/定义 正则 表达 式 模式 
/进行 preg_match_all 处 理 


这 个 例子 是 对 上 一 个 例子 做 了 简单 的 修改 ， 只 是 把 其 中 的 参数 做 了 更 换 。 保 存 以 上 代码 为 


“12-13.php”， 在 PHP 执行 环境 下 执行 该 文件 ， 其 
执行 结果 将 会 如 图 12.13 所 示 。 

从 上 例 及 图 12.13 的 执行 结果 可 以 了 解 到 ， 经 过 
加 上 PREG_SET_ ORDER 参数 的 preg_match_all 函数 
的 处 理 使 得 $out[0] 为 第 1 组 匹配 的 数组 ，$out[1] 为 第 
2 组 匹配 的 数组 。 从 中 也 能 了 解 使 用 此 参数 与 
PREG PATTERN ORDER 参数 的 区 别 。 


12.3.4 正则 表达 式 匹配 


Foree enteh_all Kua ME 


< loi 
| 文件 中 aO IEO MW IAD” P 


example: 


exanple: ， 
this is a test 
, this is a test 


zi 


LIA MA KAA KAA KI E ga 


ka 


图 12.13 preg_match_all() 函 数 使 用 实例 2 执行 结果 


int preg_match(string pattern,string subject[,array matches [,int flags]]) 函 数 进行 正则 表达 式 匹配 。 在 


subject 字符 串 中 ， 搜 索 与 pattern 给 出 的 正则 表达 式 相 匹配 的 内 容 。 如 果 提 供 了 matches, WH 


会 被 搜 


索 的 结果 所 填充 。$matches[0] 将 包含 与 整个 模式 匹配 的 文本 ，S$matches[1] 将 包含 与 第 1 个 捕获 的 括号 


中 的 子 模式 所 匹配 的 文本 ， 以 此 类 推 。 


这 里 通过 实例 来 说 明 preg_match() 函 数 是 如 何 实现 对 所 给 的 字符 串 用 正则 表达 式 模式 进行 匹配 的 。 


<html> 

<head> 

<title>preg_match() 函 数 使 用 实例 </title> 
</head> 

<body> 

<? 
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$string="http://www.sohu.com"; /定义 字符 串 

$pattern="/^(http:VV)?([^V]+)1i"; /定义 正则 表达 式 模式 

preg_match($pattern,$string,$matchs); /进行 preg_match 处 理 

echo "string 的 内 容 为 : "; 

echo $string; /输出 字符 串 变量 内 容 

echo "<p>"; 

echo "经 过 preg_match 函数 处 理 过 得 出 的 主机 名 为 : "; 

echo $matchs[2]; /| 输出 取得 数组 的 第 3 个 元 素 

?> 

</body> 

</html> 

以 上 正则 表达 式 模式 实现 了 从 一 个 网 址 中 取得 主机 名 。 如 果 执 行 无 误 , 将 会 输出 “www.sohu.com”。 
保存 以 上 代码 为 “12-14.php”。 然 后 在 PHP 执行 EECECEEE 

i yan ya J eer eeen E 
环境 下 执行 该 文件 ， 其 执行 结果 将 会 如 图 12.14 i a 


string 的 内 容 为 ，http://www. schu. com 


所 示 。 
经 过 pret e matha 过 得 出 的 主机 名 
从 图 12.14 所 示 的 输出 的 执行 结果 中 知道 经 ee TAS 
过 preg_match(O) 函 数 的 处 理 (即使 用 正则 表达 式 模 n E a 


式 从 一 个 网 址 中 取得 主机 名 ) ， 正 确 的 得 出 了 相 
匹配 的 结果 。 


12.3.5” 转 义 正则 表达 式 字符 


图 12.14 preg_match() 函 数 使 用 实例 执行 结果 


string preg guote (string str[,string delimiter]) 函 数 以 str 为 参数 并 给 其 中 每 个 属于 正则 表达 式 语 法 的 
字符 前 面 加 上 一 个 反 斜 线 。 如 果 需 要 以 动态 生成 的 字符 串 作 为 模式 去 匹配 ， 则 可 以 用 此 函数 转 义 其 中 
可 能 包含 的 特殊 字符 。 简 单 地 说 ， 此 函数 的 目的 就 是 使 正则 表达 式 中 的 特殊 字符 变 成 普通 字符 。 

如 果 提供 了 可 选 参数 delimiter， 该 字符 也 将 被 转 义 。 可 以 用 来 转 义 PCRE 函数 所 需要 的 定 界 符 ， 
最 常用 的 定 界 符 是 斜 线 “/”。 正 则 表达 式 的 特殊 字符 包括: “.”、“W”、“+”、“*”、“3”、“[”、 
WA tk ,es il a Ct YA i. ed a Ta AA Ya 

下 面 为 读者 介绍 两 个 简单 的 例子 , 通过 例子 来 说 明 preg_quote() 函 数 是 如 何 使 正则 表达 式 字符 实现 
转 义 的 。 

<html> 

<head> 


<title>preg_quote() 函 数 使 用 实例 1</title> 
</head> 


S$pattern="$40 for a g3/400"; // 定 义 正则 表达 式 模式 字符 串 
$out=preg_quote($pattern,"/"); /| 进行 preg_mathc_all 处 理 
echo "pattem 的 内 容 为 : "; 

echo $pattern; /| 输出 字符 串 变量 内 容 

echo "<p>"; 


echo "经 过 preg_quote 函数 处 理 过 的 结果 为 : "; 
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echo $out; /输出 处 理 后 的 结果 
s 
</body> 
</html> 
保存 以 上 代码 为 “12-15.php”。 在 PHP 执行 ENET -oa 
ye Wa | wa > 
环境 中 运行 该 文件 ， 其 执行 结果 将 会 如 图 12.15 | 
所 示 pattern 的 内 容 为 : $40 for a ge3/400 
e 经 过 pres_quote 表 数 钼 理 过 的 结果 为 ，WW0 
以 下 给 出 一 个 实例 来 说 明 ，preg_quote() 函 数 EE VI 
与 preg_replace() 函 数 配 合 使 用 给 某 个 单词 加 上 和 斜 Ell ll EC 


线 标记 。 具 体内 容 参看 以 下 代码 : 图 12.15 “preg_quote0 函 数 使 用 实例 1 执行 结果 


<html> 

<head> 

<title>preg_quote() 函 数 使 用 实例 2</title> 

</head> 

<body> 

<? 

$string-"This book is “very” difficult to find."; /定义 字符 串 

$word="*very™"; // 定 义 子 字符 串 

$out=preg_quote($pattern,"/"); /进行 preg_mathc_all 处 理 

echo "string 的 内 容 为 : "; 

echo $string; // 输 出 字符 串 变量 内 容 

$stringout=preg_replace ("/".preg_quote( $word)."/","<i>". $word."</i>",$string); 

echo "<p>"; 

echo "经 过 preg_quote 函数 处 理 过 的 结果 为 : "; 

echo $stringout; /| 输出 处 理 后 的 结果 

?> 

</body> 

<htm> pree anote () 示 涩 使 用 实例 2 = WiEERSGEE E] 
Ka J (aha mo sav sw TAO ”| i | 

保存 以 上 代码 为 “12-16.php”, 在 PHP 执行 NE 

环境 中 执行 该 文件 ， 其 执行 结果 将 会 如 图 12.16 difficult to find. 
通过 这 两 个 例子 的 学 习 ， 对 于 preg quote) a 
函数 的 使 用 ， 相 信 读 者 都 会 有 一 个 比较 清晰 的 认 


图 12.16 ”preg_quote0 函 数 使 用 实例 2 执行 结果 


识 
12.3.6 ”用 回调 函数 实现 正则 表达 式 的 搜索 与 替换 


mixed preg_replace_callback(mixed pattern,callback callback,mixed subject[,int limit]) 可 以 执行 正则 表 
达 式 的 搜索 和 替换 。 该 函数 的 功能 几乎 和 preg_replace() 一 样 ， 除 了 不 是 提供 一 个 replacement 参数 ， 而 
是 指定 一 个 callback 函数 以 外 。 该 函数 将 以 目标 字符 串 中 的 匹配 数组 作为 输入 参数 ， 并 返回 用 于 替换 
的 字符 串 。 
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下 面 通过 一 个 实例 来 说 明 preg_repalce_callback(O) 函 数 是 如 何 使 用 回调 函数 执行 正则 表达 式 的 搜索 
与 替换 的 。 


<html> 

<head> 
<title>preg_replace_callback() 函 数 使 用 实例 </title> 
</head> 


$text=" 轧 人 节 是 : 04/01/2005\n"; 
$text.=" 上 一 个 圣诞 节 平 安 夜 是 : 12/24/2004\n"; // 适 应 于 2005 年 的 文本 内 容 
function next_year($matches) // 定 义 回调 函数 


{ 

// 通 常 ，$matches[0] 是 完整 的 匹配 项 

//$matches[1] 是 第 一 个 括号 中 的 子 模式 的 匹配 项 

/以 此 类 推 

retum $matches[1].($matches[2]+1); // 返 回 函数 的 内 容 
} 

echo $text; 

echo "<p>"; 

echo preg_replace_callback("|(\d{2}/\d{2}/)(\d{4})|","next_year", $text); /执行 操作 
?> 

</body> 

</html> 


保存 以 上 代码 为 “12-17.php”， 在 PHP 执行 环境 中 执行 该 文件 ， 执 行 结果 如 图 12.17 所 示 。 
lback OMBEALA AE] 


280 RW IAD” P 
E) 


Ez 


RAHE: 04/01/2005 上 一 个 圣诞 节 平安 夜 
Æ: 12/24/2004 


BATE: 04/01/2006 上 一 个 圣诞 节 平安 夜 
Æ 12/24/2005 


W | | | | T O tee 4 


图 12.17 preg_replace_callback() 函 数 使 用 实例 执行 结果 


123.7 ”执行 正则 表达 式 的 搜索 与 替换 


mixed preg_replace(mixed pattern,mixed replacement,mixed subject[,int limit])。 执 行 正则 表达 式 的 搜 
RAE. E subject 中 搜索 与 pattern 模式 相 匹 配 的 项 ， 并 替换 为 replacement。 如 果 指定 了 limit, W 
仅 替换 limit 个 匹配 。 如 果 省 略 limit 或 者 其 值 为 -1， 则 所 有 的 匹配 项 都 会 被 替换 。 
注意 : limit 参数 是 PHP 4.0.1 加 入 的 。 

接 下 来 通过 一 个 实例 说 明 preg_repalceO) 函 数 是 如 何 进行 搜索 与 替换 的 。 下 面 函数 实现 的 功能 是 去 
掉 HTML 文档 内 的 HTML 格式 。 具 体内 容 参看 以 下 代码 : 
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<html> 

<head> 

<title>preg_replace () 函 数 使 用 实例 </title> 
</head> 


$search = array( 

"<script[^>]*?>.*?</script>'si", /去 掉 javascript 
"<[W]*?[^<>]*?>'si"， /去 掉 HTML 标记 
"(Nr\nJ)As]j+", // 去 掉 空白 字符 
"&(quot|#34);'i", // 蔡 换 HTML 实体 
"&(ampļ#38);'", 

"&(ItI#60);'i", 

"(gt #62);'i", 

"&(nbsp|#160);'i", 

"&(iexcl|#161);'i", 

"&(cent|#162);'i", 

"&(pound|#163);'i", 

"&(copy|#169);'", 

"&#(\d+),'e"); 1/ 作为 PHP 代码 运行 
$replace = array ("", 


"chr(N1) 

$document="<b>| love this game</b><p><u><h1> 用 PHP 编程 是 一 件 很 简单 的 事 
</h1></u><p><b><i><h2>HELLO WORLD! </h2></i></b>"; // 定 义 $doucment 变量 

$text = preg_replace ($search, $replace, $document); INE preg_replace 进行 处 理 
echo "原来 的 内 容 为 : "; 

echo $document; 

echo "<p>"; 

echo "经 过 preg_replace 处 理 之 后 的 内 容 为 : "; 

echo $text; 

?> 

</body> 

</html> 


把 以 上 代码 保存 为 “12-18.php”， 在 PHP 执行 环境 中 执行 该 文件 ， 其 执行 结果 会 如 图 12.18 所 示 。 
从 图 12.18 所 示 的 执行 结果 可 以 发 现 ， 经 过 preg_replace0 的 处 理 ， 原 来 包含 HTML 格式 的 内 容 ， 
全 部 被 转换 成 了 普通 字符 输出 。 
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图 12.18 ”preg_replace() 函 数 使 用 实例 执行 结果 


要 pree_rep1are 0 函 玫 使 用 实例 - Kicrosoft Tatemsi Ea. F1] 
RE WA SEV KA IAD EHU | & 
到 


原来 的 内 容 为: 


I love this game 


用 PHP 编 程 是 一 件 很 简单 的 事 


HELLO WORLD! 

经 过 preg_replace 处 理 之 后 的 内 容 为 : 

I love this gane 用 FHP 编 程 是 一 件 很 简单 的 事 EELLO 
MORLD! 


到 | 


Eg li E 


yA 


12.3.8 用 正则 表达 式 分 割 字 符 串 


201 


array preg split(string pattern,string subject[,int limit[,int fags]]) 用 正则 表达 式 分 割 字符 串 。 返 回 一 个 
数组 , 包含 subject 中 沿 着 与 pattern 匹配 的 边界 所 分 割 的 子 串 。 如 果 指 定 了 limit 参数 , 则 最 多 返回 limit 
个 子 串 ， 如 果 没 有 指定 limit 或 者 其 值 是 -1， 则 意味 着 没有 限制 ， 可 以 用 来 继续 指定 可 选 参数 flags。 

flags 可 以 是 下 列 标记 的 任意 组 合用 按 位 或 运算 符 | 组 合 ) : PREG_SPLIT_ NO_EMPTY， 如 果 设 
定 了 本 标记 , W preg_split0) 只 返回 非 空 的 成 分 ; PREG_SPLIT_DELIM_CAPTURE, 如 果 设 定 了 本 标记 ， 
定 界 符 模 式 中 的 括号 表达 式 也 会 被 捕获 并 返回 ， 本 标记 添加 于 PHP 4.0.5; PREG_SPLIT_OFFSET_ 
CAPTURE， 如 果 设 定 了 本 标记 ,对 每 个 出 现 的 匹配 结果 也 同时 返回 其 附属 的 字符 串 偏 移 量 。 注 意 这 改 
变 了 返回 的 数组 的 值 ,使 其 中 的 每 个 单元 也 是 一 个 数组 ,其 中 第 1 项 为 匹配 字符 串 , 第 2 项 为 其 在 subject 
中 的 偏 移 量 。 本 标记 从 PHP 4.3.0 起 可 用 。 

下 面 通过 一 个 实例 说 明 preg_split0 函 数 是 如 何 对 字符 串 进行 分 割 的 。 具 体内 容 参 看 以 下 代码 : 


<html> 
<head> 


<title>preg_split() 函 数 使 用 实例 </title> 


</head> 
<body> 

<? 
$str='string'; 


$chars=preg_split('//',$str,-1,PREG_SPLIT_NO_EMPTY); 


字符 串 进行 分 割 ， 结 果 保 存 到 数组 $chars 中 。 


for($i=0;$i<count($chars);$i++) 


echo $chars[$i]; 
echo", "; 

j; 

?> 

</body> 

</html> 


// 通 过 循环 输出 数组 


/使 用 PREG_SPLIT_NO_EMPTY 参数 对 
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把 以 上 代码 保存 为 “12-19:php”， 在 PHP 执行 环 mm E 
境 中 执行 该 文件 ， 其 执行 结果 会 如 图 12.19 所 示 。 | 
至 此 ，PHP 中 可 以 使 用 的 两 种 正则 表达 式 函数 ， aa i 
POSIX 扩展 模式 、Perl 兼容 模式 的 两 组 函数 就 全 部 介绍 en 
完毕 。 图 12.19 preg_splitO 函 数 使 用 实例 执行 结果 


12.4 正则 表达 式 使 用 实例 


12.2，12.3 节 为 读者 介绍 了 PHP 中 正则 表达 式 里 的 元 字符 、 表 达 式 语法 、 正 则 表达 式 的 两 组 函数 。 
经 过 12.2，12.3 节 的 学 习 ， 相 信 读 者 对 在 PHP 中 如 何 使 用 正则 表达 式 都 有 一 个 比较 清晰 的 认识 了 。 这 
一 节 ， 将 通过 一 些 实际 例子 ， 来 向 读者 做 进一步 的 说 明 。 这 些 例子 都 是 在 平常 编程 过 程 中 经 常 可 能 遇 
到 的 功能 。 了 解 和 使 用 这 些 例子 对 以 后 使 用 PHP 编写 Web 程序 将 起 到 事半功倍 的 效果 。 


12.4.1 构造 检查 E-mail 的 正则 表达 式 


这 一 小 节 来 讨论 怎么 验证 一 个 E-mail 地 址 。 通 常 一 个 完整 的 E-mail 地 址 中 有 3 个 部 分 :POP3 用 
户 名 (在 “@” 左 边 的 一 切 ) 、“@”、 服 务 器 名 就 是 剩 下 那 部 分 ) 。 用 户 名 可 以 含有 大 小 写字 母 
阿拉 伯 数 字 、 句 号 (“.”) 、 减 号 (“-”) 以 及 and FRR (“_”) 。 服 务 器 名 字 也 是 符合 这 个 规 
则 ， 当 然 下 划 线 除外 。 

现在 ， 用 户 名 的 开始 和 结束 都 不 能 是 名 点， 服务 器 的 名 称 也 是 这 样 。 还 有 用 户 名 中 不 能 有 两 个 连 
续 的 句点 ， 它 们 之 间 至 少 应 存在 一 个 字符 。 下 面 就 来 说 明 怎么 为 用 户 名 写 一 个 匹配 模式 。 代 码 如 下 : 

^[_a-zA-20-9-]+$ 

现在 的 情况 还 不 允许 句号 的 存在 。 把 它 加 上 : 

A[_a-zA-20-9-]+(\.[_a-zA-20-9-]+)*$ 

上 面 的 正则 表达 式 模式 的 意思 是 : “以 至 少 一 个 规范 字符 〈 除 .以 外 ) 开头 ， 后 面 跟着 0 个 或 者 多 
个 以 点 开始 的 字符 串 ”。 

要 使 上 面 的 正则 表达 式 模式 更 简化 一 点 ， 可 以 用 eregi0 取 代 ereg()。 因 为 eregi0) 在 进行 正则 表达 式 
模式 匹配 时 忽略 字母 字符 的 大 小 写 ， 这 样 就 不 需要 指定 两 个 范围 : “a-z” 和 “A-Z”， 只 需要 指定 一 
个 就 可 以 了 。 改 进 之 后 的 正则 表达 式 模式 如 下 : 

^[_a-z0-9-]+(\.[_a-z0-9-]+)*$ 

后 面 的 服务 器 名 字 也 是 一 样 ， 但 要 去 掉 下 划 线 。 代 码 如 下 : 

A[a-z0-9-]+(\.[a-z0-9-]+)*$ 

设 定好 了 用 户 名 及 主机 名 的 规则 ， 现 在 要 做 的 只 需要 用 “@” 符 号 把 用 户 名 及 主机 名 两 部 分 内 容 
连接 起 来 。 代 码 如 下 : 

A[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\[a-z0-9-]+)*$ 


是 完整 的 E-mail 认证 匹配 模式 了 ， 只 需要 调 
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HA FART: 


eregi("^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*$",$eamil) 


就 可 以 得 出 目标 字符 串 是 


下 面 ， 通 过 一 


<html> 
<head> 


否 为 正确 的 E-mail 地 址 了 。 
个 实例 来 验证 一 下 ， 以 上 的 结果 是 否 


<title> 使 用 正则 表达 式 检查 email 地 址 </title> 


$string1="username@hostname.com"; 
$string2="user.name@host.com.cn"; 


$string3="@"; 


$string4="username&hostname.com"; 


function panduan($string) 
{ 


E 确 。 


// 定 义 变量 $string1 
// 定 义 变量 $string2 
// 定 义 变量 $string3 
// 定 义 变量 $string4 
// 基 于 正则 定义 判断 函数 


if(eregi("^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*$",$string)) /判断 
echo $string.": 是 正确 的 email 地 址 ""; 


else 


echo $string.": 不 是 email 地 址 ! "; 


} 
panduan($string1); 
echo "<p>"; 
panduan($string2); 
echo "<p>"; 
panduan($string3); 
echo "<p>"; 
panduan($string4); 
?> 


</body> 
</html> 


保存 以 上 代码 为 “12-20.php” 
执行 环境 下 运行 该 文件 ,其 执行 结果 将 


所 示 。 


然后 在 PHP 
会 如 图 12.20 
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图 12.20 ”使 用 正则 表达 式 检查 email 地 址 执行 结果 


12.4.2 ”对 图 像 UBB 代码 进行 替换 


使 用 过 网 上 的 留言 德 、 论 坛 的 用 户 都 知道 ， 


般 情况 下 为 了 保证 网 络 的 安全 是 不 允许 用 户 直接 使 


用 HTML 代码 的 , 但 是 有 的 留言 竹 、 论 坛 等 Web 程序 却 允 许 用 户 使 用 UBB 代码 。UBB 实际 上 就 是 把 
用 户 输入 的 特定 内 容 转化 为 无 害 的 HTML 代码 ， 这 样 既 保 证 了 安全 ， 又 可 以 使 用 户 实现 诸如 贴图 、 发 


送 移动 文字 、 粘 贴 程序 代码 等 功能 。 这 一 小 节 就 带领 读者 来 实现 ， 如 何 把 图 UBB 内 容 转化 为 带 有 图 像 


的 HTML 代码 。 


UBB 图 像 代码 的 格式 一 般 是 这 样 : 


> PHP 网 络 编程 从 入 门 到 精通 


[mglurtimgl 
其 中 的 url 是 指向 一 幅 图 片 的 地 址 。 

列 出 了 和 欲 蔡 换 内 容 的 格式 ， 思 路 就 很 清晰 了 。 匹 配 内容 为 : 以 “[img]” 开 头 以 “[/img]” 结 尾 的 内 
即 上 边 的 URL 部 分 。 

\imgy(+NVimgy 

查找 出 内 容 之 后 就 是 蔡 换 了 ， 把 它 蔡 换 成 HTML 代码 : <img src=url>。 这 样 就 完成 所 要 求 的 操作 了 。 
调用 eregi_replace 函数 : 


eregi_replace("\[img\]","<img src-",$input); 
eregi_replace("\[Vimg\]",">", $input); 


这 样 就 完成 了 对 UBB 图 像 标 记 首尾 的 替换 。 这 里 为 什么 要 调用 eregi_replace0 函 数 ， 而 不 是 


ereg_replace() 函 数 呢 ? 因为 用 户 在 输入 的 时 候 很 有 可 能 不 会 区 分 大 小 写 , 即 大 小 写 两 种 情况 都 有 可 能 


生 ， 


所 以 要 采用 忽略 大 小 写 的 eregi_replace() 函 数 。 
下 面 通过 一 个 实例 来 验证 一 下 图 片 的 替换 是 否 能 正常 运 


<html> 
<head> 
<title> 对 图 像 UBB 代码 进行 替换 </title> 


$string1="[img]1.jpgl/img]"; // 定 义 变量 $string1 
$string2="[IMG]2.gif[/IMG]"; // 定 义 变量 $string2 
$temp1=eregi_replace("\[img\]","<img src=",$string1); 
$temp1=eregi_replace("\[Vimg\]",">",$temp1); 

$temp2=eregi_replace("\[img\]","<img src=",$string2); 
$temp2=eregi_replace("\[Vimg\]",">",$temp2); 

echo "<table border=1>"; 

echo "<tr>"; 

echo "<td>string1 的 内 容 为 : <p>".$string1."</td>"; 

echo "<td>string2 的 内 容 为 :<p>".$string2."</td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td> 将 string1 转化 后 的 内 容 为 : <p>".$temp1."</td>"; 

echo "<td> 将 string2 转化 后 的 内 容 为 : <p>".$temp2."</td>"; 

echo "</tr>"; 

echo "</table>"; 

?> 

</body> 

</html> 


保存 以 上 代码 为 “12-21.php”, 在 PHP 执行 环境 下 运行 该 文件 (在 执行 该 文件 之 前 , 要 把 名 为 1jpg 


及 2.gif 的 两 个 图 像 文件 放 到 该 PHP 文件 同一 路 径 下 ) ， 其 执行 结果 将 会 如 图 12.21 所 示 。 
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有 stringl1 转 化 后 的 内 容 为: 


SE CO T ET Z 
图 12.21 对 图 像 UBB 代码 进行 替换 执行 结果 

从 图 12.21 可 以 发 现 ， 经 过 对 图 像 的 蔡 换 操作 ， 把 原本 为 UBB 代码 的 内 容 转化 成 了 HTML N, E 
Web 页 面 上 显示 HTML 内 容 ， 就 显示 出 了 图 片 。 从 而 说 明 图 像 蔡 换 正 则 表达 式 的 执行 结果 是 正确 的 。 

除了 常见 的 查找 、 替 换 功 能 之 外 ， 正 则 表达 式 还 具有 如 下 两 个 功能 。 

口 提取 字符 串 

ereg() 函 数 和 eregi() 函 数 有 一 个 特性 是 允许 用 户 通 过 正则 表达 式 去 提取 字符 串 的 一 部 分 。 如 : 想 从 
path/URL 中 提取 文件 名 就 可 以 执行 如 下 面 的 操作 。 

ereg("([^\V]*)$", $pathOrUrl, $regs); 

echo $regs[1]; 

口 高 级 的 代 换 

ereg_replace() 和 eregi_replace() 也 是 非常 有 用 的 ， 假 如 用 户 想 把 所 有 的 间隔 负 号 都 替换 成 逗号 ， 就 
可 以 使 用 这 样 的 操作 o 

ereg_replace("[ MAJ", ",", trim($str)); 


12.5 本 章 小 结 


本 章 为 读者 介绍 了 PHP 中 的 正则 表达 式 ， 带 领 读 者 由 简 入 繁 地 学 习 了 什么 是 正则 表达 式 、 正 则 表 
达 式 的 构成 、 正 则 表达 式 的 语法 、PHP 中 可 以 使 用 的 关于 正则 表达 式 的 两 组 函数 ， 以 及 通过 具体 的 实 
例 进一步 巩固 了 正则 表达 式 的 使 用 。 正 如 本 章 开头 所 说 的 那样 ， 正 则 表达 式 在 进行 PHP 编程 中 有 着 相 
当 广 泛 的 应 用 。 通 过 本 章 的 学 习 相信 读者 已 经 能 够 熟练 地 掌握 正则 表达 式 知 识 了 , 这 将 会 使 以 后 的 Web 
编程 工作 变 得 更 加 轻松 。 


PHP 面向 对 象 编程 


什么 是 面向 对 和 聚 编程 
在 PHP 中 创建 和 使 用 类 
PHP 下 与 类 入 美的 函数 
PHP 下 使 用 类 的 实例 


aa aa 


通常 的 编程 语言 所 使 用 的 方法 有 两 种 : 面向 过 程 方法 ， 如 C 语言 所 采用 的 方法 ; 
面向 对 象 (OOP) 方法 ， 如 Java 所 采用 的 方法 。PHP 是 一 种 混合 语言 ， 它 同时 兼 有 面 
向 过 程 和 面向 对 象 这 两 种 能 力 。 具 体 使 用 哪 种 模式 ， 完 全 取决 于 用 户 的 选择 。 两 种 模式 
各 有 其 优 劣 。 这 一 节 将 重点 介绍 PHP 中 的 面向 对 象 编程 (OOP) 。 


本 章 内 容 包 括 : 面向 对 象 编程 的 基础 、 什 么 是 类 、 为 什么 要 用 到 类 ; 在 PHP 程序 
中 如 何 使 用 对 象 、 类 的 封装 、 为 类 添加 属性 、 为 类 添加 方法 、 类 的 继承 、 类 的 重 载 、 类 
的 引用 、 类 的 串 行 化 以 及 PHP 常用 的 对 象 操 作 函 数 等 内 容 。 通 过 对 本 章 的 学 习 ， 将 会 
使 读者 对 在 PHP 中 使 用 对 象 有 一 个 全 面 的 认识 。 
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13.1 面向 对 象 编程 (OOP) 基础 


要 想 使 用 面向 对 象 编程 (Object Oriented Program) ， 首 先 要 了 解 什么 是 面向 对 象 、 面 向 对 和 象 的 构 
成 以 及 什么 是 类 、 为 什么 要 用 到 类 的 问题 。 


13.1.1 什么 是 类 (class) 


在 了 解 什么 是 类 之 前 ， 先 来 了 解 一 下 面向 对 象 到 底 是 怎么 一 回 事 。 在 前 儿 章 为 读者 所 提供 的 例子 


中 ， 使 用 的 代码 基本 上 全 部 都 是 面 对 过 程 的 。 面 向 过 程 的 代码 一 般 看 起 来 如 下 : 
<? 
echo "HELLO WORLD!" 
?> 
这 就 是 通常 所 用 到 的 方法 。 但 是 达到 同一 个 目的 ， 面 向 对 象 的 代码 却 如 下 : 
<? 
class helloworld /定义 一 个 类 
function myprint() // 该 类 的 一 个 方法 
print "HELLO, WORLD." // 该 类 的 方法 所 实现 的 功能 是 打印 字符 串 
} 
} 
$myhelloworld =new helloworld(); /为 类 初始 化 一 个 实例 〈 对 象 ) 
$myhelloworld->myprint(); // 调 用 该 实例 的 方法 
TE 


上 面 这 段 代 码 就 是 标准 的 面向 对 象 的 做 法 。 面 向 对 象 的 做 法 通常 是 这 样 的 : 为 了 完成 一 件 事 ， 就 
要 先 定义 一 个 类 ， 然 后 给 该 类 添加 相应 的 方法 ， 然 后 再 为 这 个 类 派生 一 个 对 象 ， 让 对 象 去 执行 相应 的 
方法 ， 从 而 完成 所 需 工 作 。 

上 例 中 ，helloworld 是 一 个 类 ， 通 过 在 类 中 添加 了 一 个 现在 可 以 看 作 是 一 个 函数 的 方法 myprint()， 
该 方法 完成 的 工作 就 是 输出 一 个 字符 串 “HELLO WORLD”。 而 $myhelloworld 则 是 类 helloworld 的 一 
个 对 象 。 

从 以 上 两 组 代码 中 ， 读 者 应 该 能 够 看 得 出 面向 过 程 与 面向 对 象 的 区 别 。 面 向 过 程 的 基础 是 一 句 一 
名 的 代码 ， 而 面向 对 象 的 基础 则 是 对 象 。 

下 面 就 来 介绍 什么 是 类 。 从 简单 的 概念 入 手 ， 什 么 是 类 ? 抛 开 各 种 教材 的 定义 ， 通 俗 一 点 来 说 ， 
“类 ”就 是 “一 类 某 某 事物 ”的 简称 ， 就 这 么 简单 。 什 么 可 以 作为 “类 ” 呢 ? “人 ”就 是 一 个 类 ， 与 
这 个 类 相 区 别 ，“ 动 物 ” 和 “植物 ”就 是 另外 的 两 个 类 。 类 是 具有 相同 的 属性 定义 和 行为 表现 的 事物 
的 集合 。 以 “人 ”为 例 ， 这 个 类 具有 “国籍 ”、“ 种 族 ”、“ 年 龄 ”、“ 姓 名 ”等 属性 定义 ， 也 具有 
“走路 ”、“ 工 作 ” 等 行为 表现 。 
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但 是 ， 类 不 是 指 个 体 。 我 们 可 以 说 人 具有 国籍 ， 但 不 能 说 “人 ”这 个 类 的 “国籍 ”是 什么 ， 因 为 
“国籍 ”这 个 属性 的 表现 是 要 随 着 类 的 具体 化 而 实现 。 也 就 是 说 ， 需 要 具体 到 类 中 的 一 个 单个 的 元 素 ， 
也 就 是 这 个 类 的 一 个 “实例 ”。 类 是 虚无 的 东西 ， 一 个 概念 名 词 而 已 。 真 正 用 到 的 是 类 的 实例 ， 即 对 
象 。 例 如 一 个 公司 ， 它 的 雇员 是 一 个 一 个 的 具体 的 人 ， 而 不 是 整个 “人 类 ”。 和 套用 某 些 教材 里 的 话 ， 
类 是 现实 世界 某 些 对 象 的 共同 特征 〈 属 性 和 操作 ) 的 表示 ， 对 象 是 类 的 实例 。 

总 而 言 之 ， 类 是 变量 〈 类 的 属性 ) 与 作用 于 这 些 变量 的 函数 〈 类 的 方法 ) 的 集合 。 类 包括 该 类 的 
属性 与 方法 ， 属 性 与 方法 是 构成 类 的 基础 。 


13.1.2 为 什么 要 用 到 类 


面向 过 程 编程 存在 一 个 整 端 ， 代 码 重 用 时 非常 困难 。 这 在 大 规模 编程 中 表现 得 尤其 突出 。 面 向 过 
程 编程 时 ， 如 果 用 大 量 的 代码 来 完成 一 个 工作 ， 当 需要 重用 时 ， 唯 一 的 方法 就 是 重新 调用 这 些 代码 。 
任务 量 非常 大 ， 而 且 还 很 容易 出 错 。 

面向 过 程 的 这 个 弊端 在 面向 对 象 编程 模式 中 得 到 了 很 好 的 解决 。 类 对 代码 进行 了 封装 ， 所 以 在 进 
行 重 用 时 就 显得 非常 方便 ， 只 需要 调用 相关 类 的 方法 或 属性 就 可 以 了 。 

所 以 使 用 面向 对 象 编程 具有 如 下 优点 : 

口 易 维 护 。 采 用 面向 对 象 思想 设计 的 结构 ， 可 读 性 高 。 由 于 继承 的 存在 ， 即 使 改变 需求 ， 维 护 

也 只 是 在 局 部 模块 ， 所 以 维护 起 来 是 非常 方便 和 较 低 成 本 的 。 
O ”质量 高 。 在 设计 时 ， 可 重用 现 有 的 在 以 前 的 项 目 领域 中 已 被 测试 过 的 类 使 系统 满足 业务 需求 
并 具有 较 高 的 质量 。 

O 效率 高 。 在 软件 开发 时 ， 根 据 设 计 的 需要 对 现实 世界 的 事物 进行 抽象 ， 产 生 类 。 使 用 这 样 的 

方法 解决 问题 ， 接 近 于 日 常生 活 和 自然 的 思考 方式 ， 势 必 提 高 软件 开发 的 效率 和 质量 。 

口 易 扩 展 。 由 于 继承 、 封 装 、 多 态 的 特性 ， 自 然 可 以 设计 出 高 内 聚 、 低 耦合 的 系统 结构 ， 使 得 

系统 更 灵活 、 更 容易 扩展 ， 而 且 成 本 较 低 。 

由 于 与 面向 过 程 的 方法 相 比 具有 以 上 优点 ， 所 以 用 PHP 在 进行 大 型 项 目的 开发 时 使 用 面向 对 象 的 
编程 方法 是 必要 的 。 


13.2 在 PHP 中 创建 和 使 用 类 


以 前 在 介绍 变量 时 就 曾 提 到 过 ， 变 量 有 几 种 类 型 ， 其 中 有 两 种 类 型 比较 特殊 ， 一 种 是 数组 ， 另 一 
种 是 对 象 。 在 PHP 中 ， 对 象 可 以 看 成 是 一 种 特殊 的 变量 ， 对 象 有 属性 、 方 法 。PHP 中 具体 怎么 创建 并 
使 用 类 呢 ? 这 一 节 就 来 回答 这 个 问题 。 


13.2.1 自 建 类 一 一 类 的 封装 


前 面 提 到 过 ， 类 是 变量 与 作用 于 这 些 变量 的 函数 的 集合 。 所 以 要 创建 类 就 离 不 开 变量 与 函数 。 在 
介绍 如 何 自 建 类 之 前 ， 先 来 看 一 个 实例 。 下 面 代码 给 出 了 如 何 创 建 一 个 类 ， 并 为 类 实例 化 一 个 对 象 及 
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如 何 调 用 类 的 方法 。 
1. 创建 类 


在 使 用 一 个 类 之 前 必须 要 先 创建 类 。 创 建 类 的 语法 结构 如 下 : 


class classname 


创建 类 的 方法 由 一 个 class 关键 字 再 加 一 个 类 的 名 称 构成 。 以 下 实例 构建 一 个 购物 车 cart 类 。 代 码 


í 
} 
如 下 : 
<? 
class cart 
{ 
var $items; 
function add item($artnr,$num) 
Sthis->items[$artnr]+=$num; 
} 
function remove_item($artnr,$num) 
if($this->items[$artnr]>$num) 
$this->items[$artnr]-=$num; 
return true; 
} 
elseif($this->items[$artnr]==$num) 
unset($this->items[$artnr]); 
return true; 
$ 
else 
{ 
return false; 
} 
} 
} 


/购物 车 中 的 物品 
/将 $num 个 $artnr 物品 加 入 购物 车 


// 现 有 数量 加 上 放 入 数量 
// 将 $num 个 $artnr 物品 从 购物 车 中 取出 
/如 果 取 出 数量 小 于 现 有 总 数 


// 现 有 数量 减 去 取出 数量 
IEAA 


/如 果 要 取出 数量 与 现 有 数量 相等 
/清空 现 有 数量 值 


// 如 果 取 出 数 比 现 有 数 还 要 大 


/返回 错误 


上 面 的 代码 创建 了 一 个 名 为 cart 的 类 。 这 个 类 由 购物 车 中 的 商品 构成 的 数组 和 两 个 用 于 从 购物 车 
中 添加 和 删除 商品 的 函数 组 成 。 接 下 来 再 来 讲解 如 何 为 类 实例 化 一 个 对 象 。 


2. 创建 对 象 


只 创建 了 类 ， 而 不 为 类 实例 化 一 个 对 象 ， 那 么 类 就 不 会 起 作用 。 创 建 一 个 类 的 目的 就 是 要 为 了 使 
用 类 来 实例 化 对 象 。 下 面 就 来 介绍 如 何 为 类 实例 化 对 象 。 


创建 对 象 的 语法 如 下 : 


S$objectname=new classname 
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即 对 象 名 (记得 前 面 的 美元 符号 ) 加 “=” 符 号 再 加 上 “new” 加 上 类 名 即 可 。 
上 面 的 例子 就 创建 了 $mycart 这 样 一 个 基于 类 cart 的 对 象 。 


/创建 Smycart 对 象 
/1 调用 $mycart 对 象 的 放 入 购物 车 方法 


$mycart=new cart; 

$mycart->add_item("5",3); 

上 例 中 的 Smycart 具有 方法 add itemf), remove_item() 和 一 个 items 变量 。 它们 都 是 明显 的 函数 和 变 
量 。 在 引用 对 象 的 变量 与 函数 时 使 用 $mycart->items 及 $mycart->additems()。 所 以 调用 一 个 对 象 的 变量 
与 函数 使 用 下 面 的 语法 格式 : 

$objectname->varname; 

$objectname->functionname; 

在 使 用 一 个 对 象 的 时 候 有 一 个 问题 需要 注意 ， 如 上 例 中 的 变量 名 为 $cart->items， 而 不 是 
$cart->$items， 那 是 因为 在 PHP 中 一 个 变量 名 只 有 一 个 单独 的 美元 符号 。 

另外 ， 在 定义 类 的 时 候 ， 无 法 得 知 将 有 什么 名 字 的 对 象 来 访问 。 如 在 编写 cart 类 时 ， 并 不 知道 后 
面 对 象 的 名 称 将 会 命名 为 Smycart 或 者 其 他 的 名 称 ， 因 而 不 能 在 类 中 使 用 $cart->$items。 然 而 为 了 类 定 
义 的 内 部 访问 自身 的 函数 和 变量 ， 可 以 使 用 伪 变 量 $this 来 达到 这 个 目的 。$this 变量 可 以 理解 为 “我 自 
己 的 ”或 者 “当前 对 象 ”， 因 而 '$this->items[$artnr]+=$num' 可 以 理解 为 “我 自己 的 物品 数组 的 $artnr 计 
数 器 加 $num” 或 者 “在 当前 对 象 的 物品 数组 的 $artnr 计数 器 加 Snum”。 

下 面 把 前 面 的 例子 代码 加 以 完善 ， 让 其 有 实际 的 执行 结果 ， 从 而 使 读者 直观 地 认识 到 如 何 定义 类 ， 
实例 化 对 象 ， 引 用 类 的 变量 及 函数 。 代 码 如 下 : 


<html> 
<head> 
<title> 定 义 与 使 用 类 实例 </title> 
</head> 
<body> 
<? 
class cart 
{ 
var S$items; /购物 车 中 的 物品 
function add_item($artnr, $num) // 将 $num 个 $artnr 物品 加 入 购物 车 
$this->items[$artnr]+=$num; // 现 有 数量 加 上 放 入 数量 
} 
function remove_item($artnr,$num) // 将 $num 个 $artnr 物品 从 购物 车 中 取出 
if($this->items[$artnr]>$num) 1/ 如果 取出 数量 小 于 现 有 总 数 
$this->items[$artnr]-=$num; // 现 有 数量 减 去 取出 数量 
return true; // 返 回 真 
} 
elseif($this->items[$artnr]==$num) /如果 要 取出 数量 与 现 有 数量 相等 
unset($this->items[$artnr]); /清空 现 有 数量 值 


return true; 
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return false; 


} 

} 
$mycart=new cart; 
$mycart->add_item("5",3); 
echo "在 实现 add_item(\"5\",3) 之 后 "; 

echo "<p>"; 
echo ,当前 购物 车 内 编号 为 5 的 商品 数量 为 :"; 
echo $mycart->items["5"]; 
echo "<p>"; 
$mycart->add_item("5",10); 
echo "在 实现 add_item(\"5\",10) 之 后 "; 
echo "<p>"; 
echo "当前 购物 车 内 编号 为 5 的 商品 数量 为 :"; 
echo $mycart->items["5"]; 
echo "<p>"; 
$mycart->remove_item("5",7); 
echo "在 实现 remove_item(\"5\",7) 之 后 "; 
echo "<p>"; 
echo ,当前 购物 车 内 编号 为 5 的 商品 数量 为 : "; 
echo $mycart->items["5"]; 


// 如 果 取 出 数 比 现 有 数 还 要 大 


IRAR 


/| 创建 $imycart 对 象 
// 调 用 $mycart 对 象 的 放 入 购物 车 方法 


// 显 示 对 象 的 items["5"] 变 量 


// 调 用 $mycart 对 象 的 add_item() 函 数 


/显示 对 象 的 items["5"] 变 量 


// 调 用 $mycart RAI remove _item() 函 数 


/显示 对 象 的 items["5"] 变 量 


保存 以 上 代码 为 “13-1.php”， 然 后 在 PHP 执行 环境 下 运行 该 文件 ， 将 会 出 现 如 图 13.1 所 示 的 执 


行 结 果 。 

从 图 13.1 可 以 看 出 ， 在 实现 add_item("5",3) 
后 〈 即 向 购物 车 内 添加 3 个 编号 为 5 的 商品 ) ， 
编号 为 5 的 商品 现在 在 购物 车 内 的 数量 为 3; 实 
现 add_item("5",10) 后 ( 即 向 购物 车 内 添加 10 个 编 
号 为 5 的 商品 ) ， 数 量 再 增加 10 变 为 13; 实现 
remove_item("5",7)〔 即 把 购物 车 内 个 编号 为 5 的 
商品 减 去 7 个 ) 后 ， 数 量 减 去 7 变 为 了 6。 说 明 
类 通过 调用 类 的 方法 ， 改 变 了 对 象 的 某 些 属性 。 


13.2.2 为 类 添加 属性 


r EAT T] 
(xpo mo sTo www IAV ww |] 
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在 实现 add_item(“5”, 3) 之 后 

当前 购 构 车 内 渝 号 为 5 的 商品 数量 为 ，3 
在 实现 add_item(“5“,10) 之 后 

当前 购物 车 内 帝 号 为 5 的 商品 数量 为 ，13 
在 实现 renove_iten(“5",7) 之 后 

当前 购物 车 内 编号 为 5 的 商品 数量 为 ，6 


g 
局 着 TITI Oie YA 


图 13.1 定义 与 使 用 类 实例 执行 结果 


使 用 class 语句 创建 类 后 ， 为 类 添加 必要 的 属性 〈 即 变量 ) 是 必要 的 ， 也 是 必须 的 。 通 常情 况 下 ， 


类 都 有 属性 。 


现在 回 过 头 再 来 看 13-1.php。 其 中 ，cart 是 一 个 类 ， 而 里 面 的 items 就 是 类 的 一 个 属性 。 类 的 属性 
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通俗 地 说 也 就 是 存在 于 类 中 的 变量 。 
知道 了 这 样 的 概念 ， 就 明白 如 何 为 类 添加 属性 了 。 为 类 添加 属性 就 是 向 类 中 加 入 新 的 变量 。 下 面 
通过 一 个 实例 来 具体 说 明 如 何 为 类 添加 属性 。 代 码 如 下 : 


<html> 
<head> 
<title> 为 类 添加 属性 </title> 
</head> 
<body> 
<? 
class User 1/ 首先 定义 一 个 类 
{ 
var $name; // 用 户 的 名 字 
var $age; // 用 户 的 年 龄 
var $sex; // 用 户 的 性 别 
} 
$user1=new User; // 创 建 一 个 对 象 
$user1->name="Jack"; /为 名 字 赋 值 
$user1->age="20"; // 为 年 龄 赋值 
$user1->sex="male"; // 为 性 别 赋值 
echo "user1 的 名 字 为 :"; 
echo $user1->name:; // 显 示 名 字 
echo "<p>"; 
echo "user1 的 年 龄 为 : "; 
echo $user1->age; /显示 年 龄 
echo "<p>"; 
echo "user1 的 性 别 为 : "; 
echo $user1->sex; /显示 性 别 
?> 
</body> 
</html> 


把 以 上 代码 保存 为 “13-2.php”， 然 后 在 PHP 执行 环境 下 运行 该 文件 ， 其 执行 结果 如 图 13.2 所 示 。 
上 例 中 ,首先 创建 了 一 个 类 User, 然后 为 类 添加 了 
3 个 属性 ， 分 别 为 用 户 的 名 称 、 用 户 的 年 龄 、 用 户 的 性 
别 。 然 后 为 类 实例 化 了 一 个 对 象 Suser1， 又 给 对 象 的 每 
个 属性 赋予 了 值 。 调 用 对 象 的 属性 显示 出 相应 的 内 容 。 


[ET aixi 
IAD Hho | 以 


user1 的 名 字 为 ，Jack 
userl 的 年 龄 为 ，20 
useeri 的 性 别 为 ，male 


注意 : 在 类 中 ， 为 类 添加 属性 所 定义 的 变量 ， 只 能 使 用 WE E 


2 
RA 


关键 字 var 来 定义 。 图 13.2 为 类 添加 属性 执行 结果 
为 类 添加 属性 就 介绍 到 这 里 。13.2.3 小 节 介绍 如 何 为 类 添加 方法 。 


13.2.3 ”为 类 添加 方法 


方法 就 是 类 中 的 函数 。 调 用 类 的 方法 就 是 执行 其 中 的 函数 。 所 以 为 类 添加 方法 ， 也 就 是 给 类 中 增 


214" 


加 函数 。 
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仍然 通过 13-1.php 来 研究 如 何 为 类 添加 方法 。 在 13-1.php 中 ，cart 是 一 个 类 ， 其 中 有 两 个 函数 ， 即 


add_item(0 和 remove_item()， 这 两 个 函数 也 就 是 类 cart 的 方法 。 而 类 的 方法 也 就 是 存在 于 类 中 的 函数 。 


要 实现 为 类 中 添加 方法 ， 只 需 向 类 中 加 入 新 的 函数 就 可 以 了 。 下 面 通过 实例 来 说 明 如 何 为 类 添加 


方法 。 代 码 如 下 : 


<html> 
<head> 
<title> 为 类 添加 方法 </title> 


class Window 


var $state; 
function close window() 


$this->state="close"; 
return true; 


function open_window() 


S$this->state="open"; 
retum true; 


} 


$mywindow=new Window; 
$mywindow->state="open"; 

echo "当前 mywindw 的 状态 为 :"; 

echo $mywindow->state; 

echo "<p>"; 

$mywindow->close window(); 

echo "经 过 close_windw() 处 理 后 的 的 状态 为 : "; 
echo $mywindow->state; 

echo "<p>"; 

$mywindow->open_window(); 

echo "经 过 open_windw() 处 理 后 的 的 状态 为 : "; 
echo $mywindow->state; 

?> 

</body> 

</html> 


保存 以 上 代码 为 “13-3.php”。 然 后 在 PHP 执 


行 环 境 中 运行 该 文件 ， 其 执行 结果 将 会 如 图 13.3 
所 示 。 


上 例 中 ， 定 义 了 一 个 window 类 ， 并 为 类 添加 


了 S$state 属性 ， 即 窗户 的 开关 状态 。 然 后 为 类 添加 


// 首 先 定义 一 个 类 


// 窗 户 的 状态 
// 关 窗户 方法 


// 窗 户 的 状态 为 关 


// 开 窗户 方法 
// 窗 户 的 状态 为 开 


// 创 建 一 个 对 象 
// 窗 户 的 初始 状态 为 开 


// 显 示 窗 户 的 状态 
// 调 用 关 窗户 的 方法 
/显示 窗户 的 状态 
// 调 用 开 窗 户 的 方法 


// 显 示 窗 户 的 状态 
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当前 mywindw 的 状态 为 ，open 
经 ic ndw 0) 处 理 后 的 的 状态 为 ，close 
_winawO) 处 理 后 的 的 状态 为 ，cpen 
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13.3 为 类 添加 方法 执行 结果 
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了 两 个 方法 ， 一 个 是 close_window(0 关 窗户 的 方法 ， 另 一 个 是 open_window0O 开 窗户 的 方法 。 使 用 这 两 
个 方法 ， 可 以 改变 窗户 的 开关 状态 。 定 义 完 类 后 ， 为 类 创建 了 一 个 对 象 。 可 以 看 出 ， 通 出 两 个 方法 是 
如 何 改变 窗户 的 开关 状态 的 。 

在 类 中 为 类 添加 方法 和 平常 定义 一 个 函数 并 没有 本 质 上 的 区 别 。 关 键 是 如 果 函 数 中 要 引用 类 本 身 
的 状态 或 者 函数 要 使 用 伪 变 量 $this 加 上 想 要 引用 的 变量 或 者 函数 名 。 这 一 点 需要 引起 读者 的 注意 。 


13.24 类 的 继承 


这 一 小 节 来 研究 类 的 继承 问题 。 何 为 类 的 继承 呢 ? 通常 需要 这 样 一 些 类 ， 这 些 类 与 其 他 现 有 的 类 
拥有 相同 的 变量 和 函数 。 为 了 使 这 一 点 变 得 更 加 容易 ， 类 可 以 从 其 他 类 中 扩展 出 来 。 扩 展 或 派生 出 来 
的 类 拥有 其 基 类 或 者 父 类 的 所 有 变量 和 函数 ， 并 包含 所 有 派生 类 中 定义 的 部 分 。 类 中 的 元 素 不 可 能 减 
少 ， 也 就 是 说 不 可 以 注销 任何 存在 的 函数 或 者 变量 。 一 个 扩充 类 总 是 依赖 一 个 单独 的 基 类 ， 也 就 是 说 
不 支持 多 重 继承 。 

在 PHP 中 使 用 如 下 语句 来 实现 对 一 个 类 的 继承 : 

class Son_class extends class 


就 是 在 定义 一 个 子 类 Son class 时 后 面 加 上 extends 再 加 上 父 类 的 名 称 class 即 可 。 
下 面 把 13-3.php 的 代码 做 一 下 修改 ， 以 便 讲 解 如 何 从 一 个 父 类 中 继承 子 类 。 如 下 : 


<html> 
<head> 
<title> 类 的 继承 使 用 实例 </title> 
</head> 
<body> 
<? 
class Window // 首 先 定义 一 个 类 
{ 
var $state; // 窗 户 的 状态 
function close_window() // 关 窗户 方法 
S$this->state="close"; // 窗 户 的 状态 为 关 
function open_window() // 开 窗户 方法 
$this->state="open"; /窗户 的 状态 为 开 
} 
} 
class Who_Window extends Window /定义 一 个 子 类 继承 父 类 
var $owner; // 加 入 属性 窗户 的 所 有 人 
} 
$my_who_window=new Who window; // 实 例 化 一 个 对 象 
$my_who_window->owner="Jack"; /定义 窗户 的 所 有 人 


echo "my who window 的 owner 为 :"; 
echo "<p>"; 
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echo $my_who_window->owner; // 显 示 窗 户 的 所 有 人 
echo "<p>"; 

$my_who_window->close_window(); // 调 用 关 窗 户 事 件 
echo "my who window 的 开关 状态 为 : "; 

echo "<p>"; 

echo $my_who_window->state; /显示 窗户 开关 状态 


把 以 上 代码 保存 为 “13-4.php”， 然 后 在 PHP 执行 环境 下 执行 该 文件 ， 执 行 结果 将 会 如 图 13.4 所 示 。 
下 面 来 分 析 一 下 13-4.php。 首 先 定义 了 一 个 父 类 5 
window， 该 类 有 一 个 state 属性 与 开关 窗户 两 个 方法 。 
然后 又 定义 了 一 个 子 类 who_window， 由 于 使 用 了 
extends 关键 字 ， 并 且 后 面 跟 上 了 window 的 类 名 ， 所 
以 该 子 类 是 继承 自 父 类 window。 所 以 ，who_window Te 
类 就 拥有 父 类 的 全 部 属性 与 方法 ， 并 且 该 子 类 也 有 自 PEA amie 
己 的 属性 Sowner， 即 窗户 的 所 有 人 。 13.4 类 的 继承 使 用 实例 执行 结果 
为 类 who window 实例 化 了 一 个 对 象 my_who_ 
window。 由 于 该 对 象 是 基于 who window 创建 的 ， 而 who window 又 是 继承 于 父 类 window。 那 么 该 对 
象 就 既 有 $state 属性 也 有 $owner 属性 ， 同 时 也 有 开关 窗户 的 两 种 方法 。 而 后 面 的 执行 结果 也 证 实 了 这 


一 点 。 


my_xho_windom 的 oomer 为 ， 
Jack 


my_who_window 的 开关 状态 为 : 


EE 


13.2.5 ”类 的 重 载 


一 个 子 类 中 的 属性 或 方法 有 时 会 与 它 所 继承 的 父 类 中 的 属性 或 方法 重 名 , 这 时 就 出 现 了 类 的 重 载 。 

类 的 重 载 实际 上 是 类 属性 以 及 类 的 方法 的 重 载 。 那 么 什么 是 类 的 方法 的 重 载 呢 ? 通过 前 面 的 介绍 
了 解 到 ， 定 义 一 个 父 类 后 ， 可 以 再 定义 一 个 子 类 对 其 继承 。 这 时 就 存在 一 个 问题 ， 如 果子 类 中 又 定义 
了 和 父 类 中 一 样 的 变量 和 函数 ， 会 出 现 什么 后 果 呢 ? 这 时 ， 如 果 执行 子 类 的 某 个 方法 ， 还 将 执行 子 类 
中 同名 的 方法 ， 而 并 不 会 影响 父 类 中 相应 的 方法 。 这 一 过 程 就 叫做 类 的 重 载 。 

当然 在 子 类 中 也 可 以 访问 父 类 中 的 方法 。 不 过 要 使 用 关键 字 self 和 parent, 这 两 个 特殊 的 关键 字 是 
用 于 在 类 的 内 部 对 成 员 或 方法 进行 访问 的 。 

下 面 使 用 一 个 实例 来 向 读者 说 明 如 何 使 用 类 的 重 载 ， 以 及 如 何在 子 类 中 对 其 父 类 的 方法 的 访问 。 
代码 如 下 : 

<html> 

<head> 


<title> 类 的 重 载 使 用 实例 </title> 


</head> 


class Window 1/ 首先 定义 一 个 类 
{ 
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var $state; 
function close window() 
{ 

$this->state-"close"; 
} 
function open window() 
{ 

Sthis->state="open"; 
} 


class Who_Window extends Window 
{ 
var $owner; 
function close_window() 
i 
$this->state="close"; 
$this->owner-"Jack"; 


} 
function open window() 
í 
parent::open_window(); 


} 

$my_who_window=new Who window; 
$my who window->close window); 
echo "my who window 的 状态 为 :"; 
echo "<p>"; 

echo $my who window->state; 

echo "<p>"; 

echo "my who window 的 owner 为 :"; 
echo "<p>"; 

echo $my who window->owner; 

echo "<p>"; 
$my_who_window->owner="Li"; 
$my_who_window->open_window(); 
echo "my who window 的 状态 为 :"; 
echo "<p>"; 

echo $my_who_window->state; 

echo "<p>"; 

echo "my who window 的 owner 为 :"; 
echo "<p>"; 

echo $my_who_window->owner; 

?> 

</body> 

</html> 


// 窗 户 的 状态 
// 关 窗户 方法 


// 窗 户 的 状态 为 关 
// 开 窗户 方法 


// 窗 户 的 状态 为 开 


// 创 建 一 个 子 类 


// 加 入 属性 
// 方 法 的 重 载 


// 此 处 改变 窗户 的 状态 
// 此 处 改变 窗户 的 所 有 者 


// 方 法 重 载 
/执行 父 类 的 方法 ， 并 不 改变 所 有 者 


// 创 建 一 个 基于 子 类 的 对 象 
// 调 用 关 窗 户 事件 


// 窗 户 状态 此 时 为 关 


// 窗 户 的 所 有 者 现在 为 jack 


// 改 变 窗户 所 有 者 


// 调 用 开 窗户 事件 


// 显 示 状 态 


// 显 示 所 有 者 


把 以 上 代码 保存 为 “13-5.php”， 然 后 在 PHP 执行 环境 下 运行 该 文件 ， 其 执行 结果 将 会 如 图 13.5 


所 示 。 
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上 例 中 的 子 类 中 含有 和 父 类 中 同名 的 方法 , 即 进行 
TER. IPH close_window0 方 法 ， 不 仅 把 窗户 开关 EE 
状态 设置 为 关 ， 而 且 还 把 窗户 的 主人 设置 为 Jack。 而 Ma 


close 


open_window() 方 法 只 是 执行 父 类 中 的 方法 改变 窗户 的 
开关 状态 , 并 没有 改变 窗户 的 主人 。 从 这 里 也 可 以 看 到 ， 


my_mho_window 的 omner 为 ; 


Jack 


在 子 类 中 引用 父 类 方法 的 使 用 模式 。 要 使 用 parent 关键 a 
字 ， 后 面 还 要 加 上 “::” 双 冒号 符号 ， 然 后 在 后 面 加 上 open 
方法 名 。 例 如 下 面 的 语法 : ay. who_windon 的 omner 为 ， 
parent::method_name() 5 J 
从 以 上 例子 及 执行 结果 中 可 以 了 解 到 方法 的 重 裁 aa 
j 图 13.5 类 的 重 行 结 
是 如 何 使 用 的 。 13.5 载 使 用 实例 执行 结果 


13.2.6 ”类 的 引用 


在 一 个 类 中 使 用 了 其 他 的 类 的 属性 或 方法 就 称 为 类 的 引用 。 虽 然 这 在 理论 上 是 行 的 ， 但 不 推荐 这 
么 做 。 因 为 使 用 类 的 目的 就 是 把 一 类 有 共同 属性 的 东西 封装 起 来 ， 如 果 在 这 些 有 共同 属性 的 东西 中 再 
引用 别 的 东西 ， 感 觉 很 不 协调 ， 这 也 不 符合 面向 对 象 编程 的 初衷 。 不 过 有 关联 的 类 与 类 之 间 还 是 可 以 
互相 引用 的 ， 关 键 看 这 些 类 的 关系 。 

下 面 通过 一 个 实例 来 说 明 如 何 实现 类 的 引用 。 代 码 如 下 : 


<html> 
<head> 
<title> 类 的 引用 使 用 实例 </title> 
</head> 
<body> 
<? 
class A 1/ 创建 类 A 
{ 
function a_method() /创建 方法 
{ 
echo "I'm classA's method!" // 输 出 相应 内 容 
} 
} 
classB /| 创建 类 B 
function b_method() /| 创建 方法 
{ 
echo "I'm classB's method!"; // 输 出 相应 内 容 
A::A_method(); /引用 类 A 中 的 方法 
} 
} 
$my_b=new B; /为 类 B 实例 化 一 个 对 象 


$my_b->b_method(); // 调 用 对 象 的 方法 
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?> 

</body> 

</html> 

把 以 上 代码 保存 为 “13-6.php”， 然 后 在 PHP 执行 环境 下 运行 该 文件 ， 其 执行 结果 将 会 如 图 13.6 
所 示 。 各 类 的 引用 合用 实例 

通过 以 上 实例 及 其 执行 结果 可 以 看 出 ， 在 一 个 类 EE 
中 是 可 以 引用 另外 一 个 类 的 方法 的 。 使 用 如 下 语法 : WI 

class name::method name; = — 

Ea ETEF CO interet Z 

即 类 名 加 上 双 冒 号 再 加 上 方法 名 。 可 以 发 现 ,这 与 在 13.6 类 的 引用 使 用 实例 执行 结果 


子 类 中 引用 父 类 的 方法 有 相似 之 处 。 那 个 不 需要 使 用 
类 名 ， 而 只 用 parent 关键 字 就 代替 了 父 类 的 类 名 。 


13.2.7 ”类 的 构造 函数 


构造 函数 是 类 中 的 一 个 特殊 函数 ， 当 使 用 new 操作 符 创建 一 个 类 的 实例 时 ， 构 造 函数 将 会 自动 调 
用 。PHP 3 中 ， 当 函数 与 类 同名 时 ， 这 个 函数 将 成 为 构造 函数 。PHP 4 中 ， 在 类 中 定义 的 函数 与 类 同名 
时 ， 这 个 函数 将 成 为 一 个 构造 函数 。 

可 以 这 样 简单 地 理解 , 构造 函数 就 是 当 对 象 被 创建 时 类 中 一 定 发 生 作 用 的 函数 。 下 面 来 看 看 在 PHP 
中 如 何 创建 并 使 用 构造 函数 。 代 码 如 下 : 

<html> 


<head> 
<title> 类 的 构造 函数 使 用 实例 </title> 


class Window /首先 定义 一 个 类 
{ 

function Window() 

{ 


} 
var $state; /窗户 的 状态 


function close_window() /| 关 窗 户 方法 


Sthis->close_window!(); 


$this->state="close"; /窗户 的 状态 为 关 


} 
function open window() // 开 窗户 方法 


{ 
} 


Sthis->state="open"; /窗户 的 状态 为 开 


} 


$my_window=new Window; 
echo "my window 的 开关 状 为 :"; 
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echo "<p>"; 
echo $my_window->state; 
?> 

</body> 

</html> 


保存 以 上 代码 为 “13-7.php”， 并 在 PHP 执行 环境 下 运行 该 文件 ， 其 执行 结果 将 会 如 图 13.7 所 示 。 
为 什么 窗户 的 状态 会 是 关 的 ? 因为 在 创建 对 象 时 启动 了 类 的 构造 函数 。 在 上 例 中 ， 构 造 函 数 


Window0 的 内 容 是 什么 呢 ? 是 调用 本 类 的 close_window() 
方法 。 由 于 创建 对 象 时 启动 了 构造 函数 Window0， 而 [ate ero sso sto mo me r] 
Window(0) 函 数 又 是 调用 了 close_window() 方 法 。 也 就 是 my_Windon 的 开关 状 为 ， 

说 , 在 创建 对 象 时 就 把 窗户 的 开关 状态 设置 为 关 了 , 所 以 目 
才 会 出 现 如 图 13.7 所 示 的 执行 结果 。 BE COCO Em F 


还 有 一 点 , 如 果 构 造 函 数 带 有 参数 ,那么 在 为 类 创建 图 13.7 类 的 构造 函数 使 用 实例 执行 结果 
对 象 时 也 需要 带 上 参数 。 如 果 没 有 参数 就 会 有 “缺少 参数 ”的 出 错 提示 。 下 面 通过 一 个 简单 的 例子 来 
说 明 这 个 问题 。 代 码 如 下 : 

<html> 

<head> 


<title> 构 造 函数 的 参数 使 用 实例 </title> 
</head> 


class Temp /| 首先 定义 一 个 类 


{ 
function Temp($str) 


{ 
} 


echo $str; 


} 


$my_temp=new Temp("hello world!"); 
?> 


</body> 

</html> 

在 PHP 执行 环境 中 运行 该 文件 ， 将 会 输出 “hello world!” 的 字样 。 这 是 因为 类 Temp 的 构造 函数 
使 用 了 参数 。 所 以 创建 对 象 时 也 必须 带 上 参数 。 如 果 去 掉 参 数 ， 则 会 出 现 出 错 提示 。 

在 使 用 构造 函数 时 要 注意 一 个 问题 是 ， 当 创建 一 个 对 象 时 ， 如 果 类 没有 构造 函数 ， 而 父 类 有 构造 
函数 ， 则 父 类 的 构造 函数 将 会 被 调用 。 

这 个 问题 也 很 容易 理解 ， 这 里 就 不 再 袭 述 。 


13.3 PHP 中 与 类 、 对 象 相关 的 函数 


PHP 中 提供 了 函数 来 实现 对 类 的 相关 的 操作 。 本 节 为 读者 介绍 PHP 中 与 类 相关 的 常用 函数 。 
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O bool class_exists(string class namef,bool autoload]) 函 数 : 

量 class name 所 指 的 类 已 经 定义 ， 则 此 函数 返回 True, 

在 进行 PHP 编程 中 ， 判 断 一 个 类 是 否 被 定义 也 是 很 必要 的 ， 
一 个 对 象 。 但 如 果 类 不 存在 ， 也 就 无 法 创建 对 象 了 。 

下 面 通过 一 个 实例 来 说 明 如 何 使 用 class_exists() 函 数 来 判断 类 是 否 被 定义 。 具 体内 容 参 见 以 下 


代码 : 


<html> 

<head> 

<title>class_exists() 函 数 使 用 实例 </title> 
</head> 


class Window 


var $state; 
function close window() 


$this->state="close"; 
function open_window() 


S$this->state="open"; 


} 


} 
class Who_Window extends Window 
{ 
var $owner; 
function close_window() 
{ 
$this->state="close"; 
S$this->owner="Jack"; 


} 
} 
function f_e($string) 


if(class_exists($string)) 


echo "名 为 ".$string." 的 类 已 经 存在 ! "; 


} 


else 


echo "名 为 ".$string." 的 类 并 不 存在 ! "; 


} 


I 

f_e("Window"); 

echo "<p>"; 
f_e("Who_Window"); 


221? 


检查 类 是 否 已 定义 。 如 果 由 字符 串 变 
否则 返回 False。 
如 果 类 已 经 被 定义 就 可 以 为 该 类 创建 


/首先 定义 一 个 类 


/窗户 的 状态 
// 关 窗户 方法 


// 窗 户 的 状态 为 关 


// 开 窗户 方法 


// 窗 户 的 状态 为 开 


// 创 建 子 类 


/方法 继承 


/创建 一 个 基于 class_exists() 的 自 定义 函数 


/如 果 类 名 存在 
/打印 相应 信息 
// 如 果 类 不 存在 
/打印 相应 信息 


// 调 用 函数 


// 调 用 函数 
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echo "<p>"; 

f_e("temp_class"); // 调 用 函数 
echo "<p>"; 

?> 

</body> 

</html> 


把 以 上 代码 保存 为 “13-8.php”， 然 后 在 PHP 执行 环境 中 执行 该 文件 ， 执 行 结果 如 图 13.8 所 示 。 
通过 以 上 实例 及 执行 结果 , 用 class_exists0 函 数 EE TT EE 
来 判断 类 是 否 被 定义 是 很 方便 的 。 而 且 该 函数 使 用 P T 过 
4 TT BX: Wind á: 1 
起 来 也 很 简单 ， 此 处 不 做 过 多 解释 。 名 为 ，Whoa_Windon 的 类 已 经 存在 1 
口 array get_class_methods(mixed class name) 名 为 ，texp_slace 的 类 并 不 在 | 
函数 : 返回 由 类 的 方法 名 组 成 的 数组 。 调 ae OO zi 
用 该 函数 ， 将 返回 名 称 为 class_name 类 的 PA 
全 部 方法 名 。 通 过 这 一 个 函数 就 能 了 解 到 OS OS eiom REBT 
某 个 类 的 方法 的 情况 。 
了 解 一 个 类 的 方法 名 的 详细 情况 也 是 很 必要 的 。 知 道 类 的 方法 名 ， 就 可 以 对 其 引用 。 
下 面 通 过 一 个 实例 来 说 明 如 何 使 用 get_class_methods() 函 数 来 获得 类 的 全 部 方法 名 。 代 码 如 下 : 


<html> 
<head> 
<title>get_class_methods() 函 数 使 用 实例 </title> 
</head> 
<body> 
<? 
class Window // 首 先 定义 一 个 类 
{ 
var $state; /窗户 的 状态 
function close_window() /| 关 窗 户 方法 
$this->state="close"; /窗户 的 状态 为 关 
function open_window() // 开 窗户 方法 
$this->state-"open"; /窗户 的 状态 为 开 
} 
} 


$temp-get class methods("Window"); 
echo "类 Window 中 的 方法 有 以 下 几 个 : "; 
echo "<p>"; 
for($i=0;$i<count($temp);$i++) 


echo $tempf[$i].", "; 
} 
?> 
</body> 
</html> 
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保存 以 上 代码 为 “13-9.php”， 然 后 在 PHP 执行 环境 下 执行 该 文件 ， 其 执行 结果 如 图 13.9 所 示 。 


DD array get class vars(string class name) 8 
数 : 调用 该 函数 将 会 返回 由 类 的 默认 公有 
属性 组 成 的 关联 数组 ， 此 数组 的 元 素 以 
varname=>value 的 形式 存在 。 

在 使 用 一 个 类 并 为 其 定义 对 象 之 前 也 有 必要 


Desi class method 0) 示 妆 使 用 实例 Mirona 


LFD REV SFU HW IAV EMY 


尖 Windom 中 的 方法 有 以 下 几 个 : 


close window, open window, 


zi 
yA 


az OTT me 


了 解 类 中 变量 的 情况 。 下面 通过 实例 来 向 读者 介绍 


如 何 使 用 该 函数 来 获取 相应 的 内 容 。 具体 内 容 参看 13.9 get_class_methods() 函 数 使 用 实例 执行 结果 


以 下 代码 : 

<html> 

<head> 

<title>get_class_vars() 函 数 使 用 实例 </title> 

</head> 

<body> 

<? 

class Dog /| 首先 定义 一 个 类 

{ 
var $name; // 狗 的 名 字 
var $age; // 狗 的 年 龄 
var $birthday-"3/15"; // 狗 的 生日 
var $sex="male"; // 狗 的 性 别 


$temp-array keys(get class vars("Dog")); 

echo "类 Dog 的 属性 有 以 下 几 个 : " 

echo "<p>"; 

print r($temp); 

?> 

</body> 

</html> 

把 以 上 代码 保存 为 “13-10.php”， 然 后 在 PHP 
执行 环境 中 运行 该 文件 ， 执 行 结果 如 图 13.10 所 示 。 

为 什么 只 返回 了 两 项 内 容 呢 ? 因为 这 里 使 用 的 
PHP 版 本 低 于 4.2。 如 果 在 高 于 PHP 4.2.0 的 版 本 上 
执行 ， 输 出 结果 将 会 如 下 : bo 

Array([0]=>name [1]=>age [2]=>birthday [3]=>sex) 


O string get class([object obj]) 函 数 : 返回 对 象 
的 类 名 。 调 用 该 函数 将 会 返回 对 象 实例 obj 所 属 类 的 名 字 。 如 果 obj 不 是 一 个 对 象 ， 则 返回 
False。 
对 象 都 是 基于 类 创建 的 ， 一 般 情 况 下 ， 知 道 了 对 象 名 就 知道 了 相应 的 类 名 。 但 是 如 果 对 象 特 别 多 ， 
也 记 不 起 是 基于 哪个 类 创建 的 情况 下 ， 可 以 使 用 该 函数 。 
在 使 用 此 函数 时 有 以 下 两 种 情况 需要 引起 注意 。 


// 调 用 get_class_vars() 函 数 


Feet class vars OH ara ae 
PD RED SEV KRW IAD 帮助 0 |P 
E 


类 Dos 的 属性 有 以 下 几 个 ， 


Array ( [0] => birthday [1] => sex ) 


SIE 


CO Oie 


图 13.10 ”get_class_vars() 函 数 使 用 实例 执行 结果 
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@ 在 PHP 扩展 库 中 定义 的 类 返回 其 原始 定义 的 名 字 。 在 PHP 4 中 ，get_class0 返 回 用 户 定义 的 类 


回 类 名 定义 时 的 名 字 ， 如 同 扩展 库 中 的 类 名 一 样 。 
则 obj 为 可 选项 。 


名 的 小 写 形式 ， 但 是 在 PHP 5 中 将 返 
© 自 PHP 5 起 ， 如 果 在 对 象 的 方法 中 调用 ， 


下 面 通过 一 个 实例 来 说 明 函 数 get_class() 的 使 用 方法 。 代 码 如 下 : 
<html> 
<head> 
<title>get_class () 函 数 使 用 实例 <jtitle> 
</head> 
<body> 
<? 
class Dog 1/ 首先 定义 一 个 类 
{ 

var $name; // 狗 的 名 字 

var $age; // 狗 的 年 龄 

var $birthday; // 狗 的 生日 

var $sex; // 狗 的 性 别 
$mydog=new Dog; /实例 化 一 个 对 象 
$mydog->name="wang"; /定义 名 字 
$mydog->age="two month"; /定义 年 龄 
$mydog->birthday="3/15"; // 定 义 生 日 
$mydog->sex="male"; /定义 性 别 
echo "对 象 mydog 所 属 的 类 为 :"; 

// 调 用 函数 输出 对 象 所 属 的 类 


echo get class($mydog); 
?> 


</body> 
</html> 


把 以 上 代码 保存 为 “13-11.php” 


所 示 。 


通过 上 例 及 执行 结果 可 以 看 出 ， 


函数 返回 了 对 象 Smydog 所 属 的 类 Dog。 从 而 说 明 ， 函 
数 正确 运行 。 


， 然 后 在 PHP 执行 环境 中 执行 该 文件 ， 其 执行 结果 将 会 如 图 13.11 


| ii === 


[arp sao sev mw IAD wma | P 


调用 get class() 3 


对 和 象 mydog 所 属 的 类 为 ，dog 


zi 
YA 


Eg mi 


I Er 


口 array get_declared_classes() 函 数 : 返回 由 已 定 图 13.11 ”get_class() 函 数 使 用 实例 执行 结果 
义 类 的 名 字 所 组 成 的 数组 。 调 用 该 函数 将 会 
返回 由 当前 脚本 中 已 定义 类 的 名 字 组 成 的 数组 。 注 意 ， 此 函数 并 没有 任何 参数 。 


由 于 PH 中 有 预定 义 类 ， 即 系统 自动 生成 的 类 ， 所 以 使 用 该 函数 将 会 有 几 个 预定 义 类 存在 于 返回 
的 数组 中 ， 分 别 为 stdClass、_PHP_Incomplete_Class、Directory。 同 时 ， 由 于 有 这 些 预 定义 类 的 存在 ， 
所 以 在 创建 类 时 不 能 使 用 这 些 预 定义 类 名 作为 类 的 名 称 。 
下 面 通过 一 个 实例 来 说 明 函 数 get_declared_classes() 的 使 用 方法 。 代 码 如 下 : 
<html> 
<head> 
<title>get declared _classes() 函 数 使 用 实例 </title> 
</head> 
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<body> 
<? 
class Dog 
í 
var $name; 
var $age; 
var $birthday; 
var $sex; 
} 
class Window 
{ 
var $state; 
function close window() 
{ 
S$this->state="close"; 
} 
function open window() 
1 
S$this->state="open"; 
} 


} 
class Who_Window extends Window 
{ 
var $owner; 
function close_window() 
{ 
$this->state="close"; 
$this->owner-"Jack"; 


} 


= 225" 


/定义 一 个 类 Dog 

// 狗 的 名 字 

// 狗 的 年 龄 

// 狗 的 生日 

// 狗 的 性 别 
/定义 一 个 类 Window 


/窗户 的 状态 
// 关 窗户 方法 


// 窗 户 的 状态 为 关 
// 开 窗户 方法 
// 窗 户 的 状态 为 开 


/| 创建 Window 的 子 类 Who Window 


/方法 继承 


让 至 此 ， 此 PHP 文件 中 一 共 定义 有 3 个 类 ， 分 别 是 : Dog、Window、Who_Window。 
现在 调用 get_declared_classes() 函 数 ， 看 能 否 正 确 返回 */ 


$temp-get declared classes(); 
for($i=0;$i<count($temp);$i++) 


echo "数组 的 第 ".$i." 个 元 素 为 : "; 
echo $temp[$i]; 
echo "<p>"; 

} 

?> 

</body> 

</html> 


// 调 用 函数 ， 把 结果 保存 到 变量 中 
/通过 循环 显示 数组 所 有 元 素 


保存 以 上 代码 为 “13-12.php”， 然 后 在 PHP 执行 环境 中 运行 该 文件 ， 其 执行 结果 会 如 图 13.12 


所 示 。 


从 图 13.12 可 以 看 出 ， 由 于 有 预定 义 类 的 存在 ， 所 以 函数 首先 返回 了 6 个 预定 义 类 : stdClass、 
— PHP Incomplete Class, OverloadedTestClass, Directory, COM, VARIANT (HF PHP 版 本 的 不 同 ， 


返回 的 预定 义 类 可 能 也 会 有 所 不 同 ) ， 然 后 才 返 回 3 个 


户 自 定义 类 : dog, window, who window. 
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array get object vars(object obj) 函 数 : 该 函数 返 et declared esses ASEMA nii 
回 由 对 象 属性 组 成 的 关联 数组 。 ER 
menant anaswa epp [mmmn 
4.2.0 之 前 的 版 本 中 ， 如 果 在 obj 对 象 实例 中 声明 的 KAN Aa 
变量 没有 被 赋值 ， 则 它们 将 不 会 在 返回 的 数组 中 。 数组 的 第 3 个 元 素 鸭 ,Dizccta 
而 在 PHP 4.2.0 以 后 的 版 本 中 ， 这 些 变量 作为 键 名 数组 的 第 4 个 元 过 为， 
将 被 赋予 NULL 值 。 数组 的 第 5 个 元 这 为 ， 
下 面 给 出 一 个 实例 来 说 明 函 数 get object vars() 数组 的 第 6 个 元 素 为 ，dog 
是 如 何 获得 对 象 属性 的 。 代 码 如 下 : BANG ABA winda 
数组 的 第 8 个 元 素 为 ，who_window 
<html> a 
<head> [OE COOU Oe YA 


<He>get ohject van KIE ASEE Hiie» 图 13.12 get_declared_classes0 函 数 使 用 实例 执行 结果 


</head> 
<body> 
<? 
class Dog 1/ 首先 定义 一 个 类 
f 

var $name; // 狗 的 名 字 

var $age; // 狗 的 年 龄 

var $birthday; // 狗 的 生日 

var $sex; // 狗 的 性 别 
} 
$mydog=new Dog; // 实 例 化 一 个 对 象 
$mydog->name="wang"; /定义 名 字 
$mydog->age="two month"; /定义 年 龄 
$mydog->birthday="3/15"; // 定 义 生日 
$mydog->sex="male"; /定义 性 别 
$temp-get object vars($mydog); // 调 用 函数 把 对 象 的 属性 赋值 给 数组 
print r($temp); 
7> 
</body> 
</html> 


把 以 上 代码 保存 为 “13-13.php”， 在 PHP 执行 环境 下 运行 该 文件 ， 其 执行 结果 将 会 如 图 13.13 
所 示 。 


用 实 aloj xi 

从 如 图 13.13 所 示 的 执行 结果 中 可 以 看 出 ， J Le 
函数 返回 了 对 象 Mydog 的 所 有 属性 及 其 值 。 这 说 kerar ( Doel 二 人 “| 国 
明 该 函数 get_object_vars() 正 确 运行 。 a 


ar [ l 


[ID nternet 


: AI 图 13.13 “get_object_vars() 函 数 使 用 实例 执行 结果 
象 ， 则 返回 对 象 实例 obj 所 属 类 的 父 类 名 。 如 果 obj 是 字符 串 ， 则 返回 以 此 字符 串 为 名 的 类 的 
父 类 名 。 此 功能 是 在 PHP 4.0.5 中 增加 的 。 另 外 ， 自 PHP 5 起 ， 如 果 在 对 象 的 方法 内 调用 ， 则 
obj 为 可 选项 。 

下 面 通过 实例 来 说 明 如 何 使 用 get_parent_class0) 函 数 来 返回 对 象 或 类 的 父 类 名 。 代 码 如 下 : 
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<html> 

<head> 

<title>get_parent_class() 函 数 使 用 实例 </title> 
</head> 


class Window 

{ 
var $state; 
function close window() 
{ 


S$this->state="close"; 


function open window() 
{ 
$this->state="open"; 


} 


} 
class Who_Window extends Window 
{ 
var $owner; 
function close window() 
{ 
$this->state="close"; 
$this->owner-"Jack"; 


} 


J 

$my_who_window=new Who_Window; 
$temp1=get_parent_class("Who_Window"); 
$temp2=get_parent_class($my_who_window); 
echo "类 Who Window 的 父 类 为 : "; 

echo "<p>"; 

echo $temp1; 

echo "<p>"; 


echo "Ri my who window 所 属 类 的 父 类 为 : "; 


echo "<p>"; 
echo $temp2; 
?> 

</body> 
</html> 
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/定义 一 个 类 Window 


/窗户 的 状态 
// 关 窗户 方法 


// 窗 户 的 状态 为 关 
// 开 窗户 方法 
// 窗 户 的 状态 为 开 


/| 创建 Window 的 子 类 Who Window 


/方法 继承 


/实例 化 一 个 对 象 
INAM get_parent_class() 把 结果 赋值 给 变量 
UKAA get_parent_class() 把 结果 赋值 给 变量 


/| 输出 结果 


/| 输出 结果 


把 以 上 代码 保存 为 “13-14.php”， 在 PHP 执行 环 


境 中 运行 该 文件 ， 其 执行 结果 如 图 13.14 所 示 。 


通过 上 例 可 以 看 出 ,第 1 次 调用 get_parent_class() 


函数 时 使 用 的 参数 是 字符 串 ， 即 子 类 的 名 称 ， 函 数 能 
正确 返回 父 类 的 名 称 ; 第 2 次 调 
象 名 ， 函 数 返 回 了 对 象 Smy_who_window 所 属 的 类 
Who_Window 的 父 类 Window。 通 过 两 次 调用 可 以 看 


时 使 用 的 参数 是 对 


ET 


类 Who_ 由 ndon 的 父 类 为 : 
window 
对 象 m_who_windon 所 属 类 的 父 类 为 ， 


window 


B 
ZA 


[Ea 可 


图 13.14 get_parent_class() 函 数 使 用 实例 执行 结果 


CID tent 
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出 ， 函 数 get_parent_class0 不 仅 能 返回 子 类 的 父 类 名 称 ， 也 能 返回 对 象 所属 子 类 的 父 类 。 
口 ”bool is_subclass_of(object object,string class_name) 函 数 : WRI object 所 属 类 是 类 class_name 
的 子 类 ， 则 返回 True， 和 否则 返回 False。 此 函数 的 目的 是 判断 某 个 对 象 是 否 属于 某 个 类 ， 或 者 
是 其 父 类 。 
下 面 通过 一 个 实例 来 说 明 如 何 使 用 is_sub_of0) 函 数 来 进行 对 象 与 类 的 关系 的 判断 。 代 码 如 下 : 


<html> 
<head> 
<title>is_subclass_of() 函 数 使 用 实例 </title> 
</head> 
<body> 
<? 
class Window /| 首先 定义 一 个 类 
{ 
var $state; /窗户 的 状态 
function close_window() /| 关 窗 户 方法 
$this->state="close"; /窗户 的 状态 为 关 
} 
function open window() // 开 窗户 方法 
$this->state-"open"; /| 窗户 的 状态 为 开 
} 
} 
class Who_Window extends Window /| 创建 Window 的 子 类 Who Window 
{ 
var $owner; 
function close_window() /方法 继承 
{ 
S$this->state="close"; 
$this->owner-"Jack"; 
3 
} 
function is sub e($0bj,$string) /创建 一 个 基于 is_subclass_of() 的 自 定义 函数 
iflis subelass 0f($0bj,$string)) // 如 果 类 名 存在 
echo "对 象 属于 名 为 ".$string." 的 类 的 子 类 的 对 象 ! "; // 打 印 相应 信息 
} 
else // 如 果 类 不 存在 
echo "对 象 不 属于 名 为 ".$string." 的 类 的 子 类 的 对 象 ! "// 打 印 相应 信息 
} 
} 
class Dog /| 首先 定义 一 个 类 
{ 
var $name; // 狗 的 名 字 


var $age; // 狗 的 年 龄 
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var $birthday; 

var $sex; 
} 
$my_window=new Who Window; 
is sub e($my window,"Who Window"); 
echo "<p>"; 
is_sub_e($my_window,"Window"); 
echo "<p>"; 
is_sub_e($my_window,"Dog"); 
?> 
</body> 
</html> 


// 狗 的 生日 
// 狗 的 性 别 
/调用 自 定义 函数 
1/ 调用 自 定义 函数 


/调用 自 定义 函数 


保存 以 上 代码 为 “13-15.php”， 然 后 在 PHP 执行 环境 中 运行 该 文件 ， 其 执行 结果 将 会 如 图 13.15 


所 示 。 

从 图 13.15 可 以 看 出 ， 由 于 对 象 Smy_window 
是 基于 类 Who_window 建立 的 ,而 类 Who_window 
又 是 类 window 的 子 类 ， 所 以 执行 is_subclass_oft) 
函数 , 在 列 出 的 3 个 类 中 只 有 window 类 是 符合 条 
件 的 。 所 以 图 13.15 中 只 有 第 2 次 输出 了 属于 的 信 
息 ， 其 他 两 次 都 输出 不 属于 的 信息 。 


Dis subclass HUU sini 
| 文件 四 ASO HEV HRW IAV HHW | 葵 


对 象 不 属于 名 为 Who_Windon 的 类 的 子 类 的 对 象 ! 
对 象 属 于 名 为 Window 的 类 的 子 类 的 对 象 
对 得 不 属于 名 为 Dos 的 类 的 子 类 的 对 得 1 


[D ternet 


图 13.15 is_subclass_oft) 函 数 使 用 实例 执行 结果 


O bool method_exists(object object,string method_name) 函 数 : 该 函数 检查 object 类 的 method name 
方法 是 否 存在 。 如 果 存 在 ， 函 数 返回 True， 反 之 则 返回 False。 
下 面 给 出 一 个 实例 来 说 明 函数 method_exists() 是 如 何 对 对 象 的 方法 进行 操作 的 。 代 码 如 下 : 


<html> 

<head> 

<title>method_exists() 函 数 使 用 实例 </title> 
</head> 


class Window 
{ 
var $state; 
function close window() 
{ 
$this->state="close"; 


} 


function open_window() 


Sthis->state="open"; 
} 


} 
function method e($0bj,$string) 


if(method_exists($obj,$string)) 


/首先 定义 一 个 类 


/窗户 的 状态 
// 关 窗户 方法 


// 窗 户 的 状态 为 关 
// 开 窗户 方法 
// 窗 户 的 状态 为 开 


/创建 一 个 基于 method_exists 的 自 定义 函数 


// 如 果 类 名 存在 
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echo "对 象 中 名 为 ".$string." 的 类 已 经 存在 ! "; /打印 相应 信息 
else // 如 果 类 不 存在 
echo "对 象 中 名 为 ".$string." 的 类 并 不 存在 ! "; /打印 相应 信息 
} 
$my_window=new Window; 
method_e($my_window,"open_window"); /调用 自 定 义 函 数 
echo "<p>"; 
method e($my. window,"close window"); /调用 自 定义 函数 
echo "<p>"; 
method_e($my_window,"temp_method"); /调用 自 定义 函数 
?> 
</body> 
</html> 


保存 以 上 代码 为 “13-16.php”， 在 PHP 执行 环境 
下 运行 该 文件 ， 执 行 结果 将 会 如 图 13.16 所 示 。 

从 图 13.16 可 以 看 出 ,通过 调用 基于 method_exists0 
函数 的 自 定义 函数 ,正确 地 对 对 象 中 的 方法 情况 进行 了 
判断 。 上 例 中 , 由 于 open window 方法 与 close_window 
方法 均 已 经 存在 ,所 以 返回 存在 的 信息 。 而 temp_method DE mi 
则 没有 存在 ， 所 以 返回 方法 不 存在 的 信息 。 图 13.16 ”method_exists0 函 数 使 用 实例 执行 结果 


对 象 中 名 为 open_windon 的 类 己 经 存在 1 


对 象 中 名 为 cloce_windon 的 类 已 经 存在 1 
对 象 中 名 为 tecnp_mcthod 的 类 并 不 存在 1 


I Er 


BA 类 的 具体 使 用 实例 


本 节 将 综合 前 面 几 节 所 学 习 的 内 容 ， 做 一 个 实例 来 实际 地 应 用 学 的 知识 。 本 实例 实现 的 功能 是 用 
PHP 面向 对 象 的 特性 写 一 个 完全 的 购物 车 类 。 有 具体 内 容 参看 以 下 代码 : 
<html> 
<head> 
<title> 面 向 对 象 的 具体 使 用 一 一 购物 车 类 </title> 
</head> 
<body> 
<? 
class ShopCar // 类 名 购物 车 类 
{ 
var $carName; // 属 性 购物 车 名 字 
var $debug; /属性 
function ShopCar($carName) /创建 购物 车 方法 构造 函数 ) 
$this->carName=$carName; // 将 购物 车 命名 为 指定 名 称 
if(lisset($_SESSION[$carName])) // 如 果 没 有 保存 为 session 
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{ 
$_SESSION[$carName]=array(); 
J 
} 
function addCar($type,$name,$val) 


i 
if(array_key_exists($type,$_SESSION[$this->carName])) 


if(array_key_exists($name,$_SESSION[$this->carName][$type])) 


{ 

if($this->debug)echo "<p> 已 有 {$name} 商 品 ,不 必 增 加 <p>"; 
return false; 

} 


else 


$_SESSION[$this->carName][$type][$name]=$val; 


else 
$_SESSION[$this->carName][$type]=array($name=>$val); 
retum true; 
laian editCar($type,$name,$var) 
i if(!array_key_exists($name,$_SESSION[$this->carName][$type])) 


if(Sthis->debug)echo "<p> 没 有 {$name} 商 品 ,修改 失败 <p>"; 
return false; 


} 
$_SESSION[$this->carName][$type][$name]=$var; 
retur true; 


} 
function delCarType($type) 
{ 
if(!larray_key_exists($type,$_SESSIONI[S$this->carName])) 


if($this->debug)echo "<p> 没 有 {$type} 类 别 ,删除 失败 <p>"; 


return false; 


} 
unset($_SESSION[$this->carNamej[$type]); 
retum true; 


} 
function delCarPro($type, $name) 
if(!larray_key_exists($name,$_SESSION[S$this->carNamel][$type])) 


if($this->debug)echo "<p> 没 有 {$name} 商 品 ,删除 失败 <p>"; 
return false; 


s21” 


// 把 购物 车 名 称 保 存 到 session 


// 向 购物 车 中 增加 商品 方法 
// 如 果 类 别 已 经 存在 


// 如 果 商 品 存在 


/| 输出 相应 信息 
// 返 回 假 


// 如 果 商 品 不 存在 


/在 session 中 设 定 


// 如 果 类 别 不 存在 
// 在 sessuib 是 设 定 
// 返 回 真 值 

/| 编辑 购物 车 方法 
// 如 果 类 别 不 存在 


// 输 出 错误 信息 
/返回 假 值 


/在 session 中 设 定 


/删除 购物 车 类 别 
// 如 果 类 别 不 存在 


/| 输出 错误 信息 
NEMRE 


/在 session 中 删除 
// 返 回 真 值 


/删除 商品 
/如 果 商 品 不 存在 


/| 输出 错误 信息 
// 返 回 假 值 
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} 
unset($_SESSION[Sthis->carName][S$type][$name]); /在 session 中 删除 
retum true; // 返 回 真 值 
} 
function delCar() // 删 除 购物 车 
í 
session unregister($this->carName); /在 session 中 注销 
} 
function getCarData() // 获 取 购 物 车 数据 
í 
return $_SESSION[$this->carName]; // 通 过 session 返回 
} 
} 
$my_car=new Shopcar("my_shopcar"); /| 创建 对 象 时 一 定 要 带 参数 ， 
否则 会 有 出 错 提示 。 
$my_car->addCar(" 水 果 "," 苹 果 ",10); /为 购物 车 添加 商品 


$my_car->addCar(" 水 果 "," 香 蕉 ",5); 
$my_car->addCar(" 水 果 "," 梨 ",4); 
$my_car->addCar(" 蔬 菜 "," 白 菜 ",10); 
$my_car->addCar(" 蔬 菜 "," 萝 卜 ",3); 
$my_car->addCar(" 蔬 菜 "," 菠 菜 ",12); 
$my_car->addCar(" 蔬 菜 "," 茄 子 ",8); 
$temp=$my_car->getCarData(); 
print_r ($temp); 

?> 


</body> 

</html> 

上 例 创 建 了 一 个 功能 完善 的 购物 车 类 ， 既 可 以 单独 使 用 ， 也 可 以 通过 连接 数据 库 ， 形 成 一 个 功能 
强大 的 在 线 购 物 平台 。 保 存 以 上 代码 为 “13-17.php”， 然 后 在 PHP 执行 环境 中 运行 该 文件 ， 执 行 结 果 


将 会 如 图 13.17 所 示 。 本 
通过 图 13.17 可 以 看 到 ， 通 过 addCar0 方 法 向 购物 车 reese ae eaw ao me Le 
中 添加 了 部 分 商品 ， 又 通过 getCarData0 方 法 获取 了 各 类 5 HEE pR: eT TERTS 
商品 的 相关 信息 。 另 外 ， 该 类 中 的 删除 商品 、 删 除 购物 车 图 
等 方法 也 都 是 非常 有 用 的 , 有 兴趣 的 读者 可 以 继续 完善 Ee; 
面 的 例子 ， 以 验证 各 种 方法 的 正确 性 。 这 里 就 不 再 次 述 。 图 13.17 购物 车 类 执行 结果 
13.5 本 章 


本 章 主要 带领 读者 学 习 了 PHP 的 面向 对 象 编程 的 特性 。 学 习 了 什么 是 类 ， 什 么 是 对 象 ， 如 何 使 用 
类 ，PHP 中 与 类 及 对 象 相关 的 函数 。 正 如 本 章 开始 所 提 到 的 那样 ， 编 程 语言 的 方法 有 面向 对 象 与 面向 
过 程 两 种 ， 有 具体 采 用 那 种 方法 ， 完 全 取决 于 用 户 的 喜好 。 但 是 作者 还 是 提议 ， 在 写 小 型 程序 ， 代 码 不 
多 的 情况 下 ， 采 用 面向 过 程 的 方法 要 好 一 点 。 同 样 ， 当 开发 大 型 项 目 ， 代 码 动 辆 成 千 上 万 行 时 ， 采 用 
面向 对 象 的 编程 方法 能 更 好 地 提高 工作 效率 。 
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使 用 MySQL 数据 库 
ais 


美 系 型 数据 库 基础 

RA PHP 对 数据 库 弄 行 操作 
BRA PHP SERIE 
Kuugua 
数据 库 使 用 实例 


aa aaa 


只 有 和 与 数据 库 相 结合 ， 才 能 发 挥动 态 网 页 编程 语言 的 魅力 ， 因 为 网 上 的 众多 应 用 都 
是 基于 数据 库 的 。 虽 然 PHP 支持 多 种 数据 库 ， 但 PHP 与 MySQL 可 称 得 上 是 黄金 组 合 。 
这 一 章 就 带领 读者 来 学 习 My5QL。 本章 内 容 包括 关系 型 数据 库 基 础 、 PHP 中 与 MySQL 
相关 的 常用 函数 、 如 何 创建 一 个 数据 库 、 如 何在 PHP 文档 中 执行 SQL 语句 、MySQL 
表 的 高 级 查询 等 内 容 。 最 后 还 将 通过 一 个 实例 一 班级 学 生 管 理 系统 ， 来 巩固 本章 的 知 
识 。 通 过 本 章 的 学 习 会 使 读者 能 够 熟练 的 写 出 基于 数据 库 的 Web 应 用 程序 。 
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14.1 关系 型 数据 库 基 础 


通常 所 说 的 数据 库 有 两 种 类 型 : 一 种 是 以 库 、 表 为 基础 的 关系 型 数据 库 ， 另 一 类 是 用 文本 文件 、 
或 者 二 进 制 文件 作为 数据 载体 的 文本 型 数据 库 。 这 一 节 来 介绍 关系 型 数据 库 。 


14.1.1 什么 是 关系 型 数据 库 


关系 型 数据 库 以 行 和 列 的 形式 存储 数据 ， 以 便于 用 户 理 解 。 这 一 系列 的 行 和 列 被 称 为 表 ， 一 组 表 
组 成 了 数据 库 。 用 户 用 查询 (Query) 来 检索 数据 库 中 的 数据 。 一 个 Query 是 一 个 用 于 指定 数据 库 中 行 
和 列 的 SELECT 语句 。 

关系 型 表 (TABLE) 是 构成 关系 型 数据 库 (DATABASE) 的 基础 。 表 是 由 这 样 的 结构 构成 ， 用 列 
(COLS) 表示 的 字段 与 用 行 ROWS) 表示 的 记录 。 这 样 说 还 是 有 点 抽象 ， 举 一 个 实际 的 例子 来 说 明 
这 个 问题 ， 如 某 一 个 班级 全 体 学 生 的 考试 成 绩 表 是 一 个 表 。 用 列 来 表示 每 一 个 科目 ， 用 行 来 表示 每 一 
个 学 生 的 成 绩 情况 。 这 样 ， 这 个 表 里 面 的 每 一 个 科目 ， 如 语文 、 数 学 、 英 语 、 物 理 、 化 学 、 政 治 、 历 
史 等 科目 的 成 绩 就 可 以 被 看 作 是 表 字 段 。 而 记录 每 一 个 学 生 分 数 的 行 ， 如 学 生 张 三 、 李 四 、 王 五 、 赵 
六 这 些 信 息 就 可 以 被 看 作 是 表 的 记录 。 


141.2 ”关系 型 数据 库 的 功能 


数据 库 最 基本 的 功能 就 是 作为 数据 存储 的 载体 。 所 以 ， 存 储 各 种 各 样 的 数据 是 数据 库 的 最 基本 的 
功能 。 当 然 除 了 这 个 最 基本 的 功能 之 外 ， 关 系 型 数据 库 还 具有 如 下 功能 。 

口 ”复杂 的 数据 计算 。 把 数据 存放 于 数据 库 后 并 不 是 已 经 完成 任务 了 ， 加 入 数据 只 是 数据 库 应 用 
的 开始 。 可 以 利用 数据 库 的 强大 计算 功能 来 实现 复杂 的 数据 计算 。 

O 数据 统计 。 有 的 时 候 还 需要 对 存放 于 数据 库 之 中 的 数据 进行 某 一 类 别 的 统计 。 如 果 这 项 工作 
靠 人 力 来 完成 ， 工 作 量 是 相当 可 观 的 。 而 对 于 大 型 的 数据 库 来 说 几乎 是 不 可 能 完成 的 。 而 依 
靠 数据 库 则 可 以 在 很 短 时 间 内 完成 对 数据 的 统计 工作 。 

O 数据 检索 。 有 时 还 需要 对 数据 进行 搜索 。 在 关系 型 数据 库 中 执行 select 语句 能 够 在 很 短 的 时 
间 内 检索 出 所 要 的 结果 。 

O ”其 他 功能 。 除 此 之 外 ， 关 系 型 数据 库 还 有 其 他 一 些 功能 ， 如 构建 搜索 引擎 、 游 戏 服务 器 存放 
游戏 玩家 数据 等 。 


14.2 PHP 中 与 MySQL 数据 库 相 关 的 函数 


这 一 节 先 来 学 习 PHP 中 的 与 MySQL 数据 库 操作 相关 的 函数 。 通 过 对 这 些 函 数 的 学 习 ， 会 使 读者 
对 在 PHP 中 如 何 操作 数据 库 有 一 个 比较 全 面 的 了 解 。 
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下 面 就 分 别 为 读者 逐个 介绍 PHP 中 与 MySQL 数据 库 操 作 相关 的 常用 函数 〈 如 果 读 者 觉得 下 面 的 
内 容 枯燥 无 味 可 以 先 简单 浏览 一 下 ， 跳 过 这 一 节 ， 直 接 看 后 面 的 内 容 ， 遇 到 相关 的 函数 再 回来 查 会 比 
较 好 ) 。 
口 int mysql_affected_ rows([resource link identifier]) 函 数 。 调 用 此 函数 将 返回 前 一 次 MySQL 操作 
所 影响 的 记录 行 数 。 此 操作 包括 insert, update, delete 3 项 查询 查询 的 操作 。 
O bool mysql_close([resource link_identifier]) 函 数 。 关 闭 MySQL 连接 。mysql_close() 关 闭 指定 的 
连接 标识 所 关联 的 、 到 MySQL 服务 器 的 非 持久 连接 。 如 果 没 有 指定 link_identifier， 则 关闭 上 
一 个 打开 的 连接 。 通 常 不 需要 使 用 mysql_close(0) 来 关闭 连接 ， 因 为 已 打开 的 非 持 入 连接 会 在 
脚本 执行 完毕 后 自动 关闭 。 
口 resource mysql_connect([string server[,string username[,string password[,bool new_link[, int 
client_flags]]]]]) 函 数 。 打 开 一 个 到 MySQL 服务 器 的 连接 。 该 函数 的 参数 如 下 : server， 可 用 
的 MySQL 服务 器 。 可 以 包括 端口 号 ， 例 如 "hostname:port"， 或 者 到 本 地 套 接 字 的 路 径 ， 例 如 
对 于 localhost 的 ":/path/to/socket"。 如 果 在 PHP.INI 中 指令 mysql.default_host REX CRUT 
况 ) ， 则 默认 值 是 'localhost:3306'。username， 用 户 名 ,默认 值 是 服务 器 进程 所 有 者 的 用 户 名 。 
password, 密码 , 默认 值 是 空 密码 。new_link,， 如 果 用 同样 的 参数 第 2 次 调用 mysql_connect()， 
将 不 会 建立 新 连接 ， 而 将 返回 已 经 打开 的 连接 标识 。 参 数 new_link 改变 此 行为 并 使 
mysql_connect() 总 是 打开 新 的 连接 ， 甚 至 当 mysql_connectO 曾 在 前 面 被 用 同样 的 参数 调用 过 。 
client_flags， 该 参数 可 以 是 以 下 常量 的 组 合 , MYSQL_CLIENT_SSL, MYSQL_CLIENT_ 
COMPRESS，MYSQL CLIENT IGNORE SPACE 或 MYSQL CLIENT_INTERACTIVE。 这 
儿 个 参数 的 意义 分 别 如 表 14.1 所 示 。 


表 14.1 MySQL 客户 端 常量 


常量 
MYSOL CLIENT COMPRESS 
MYSOL CLIENT IGNORE SPACE 
MYSOL CLIENT INTERACTIVE 


使 用 压缩 的 通讯 协议 

允许 在 函数 名 后 留 空格 位 

允许 设置 断 开 连 接 之 前 所 空闲 等 候 的 interactive timeout 时 间 〈 代 替 wait timeout) 
使 用 SSL 加 密 。 本 标志 仅 在 MySQL 客 户 端 库 版 本 为 4.x 或 更 高 版 本 时 可 用 。 在 


MYSOL.-CLIENT SSL PHP 4 和 Windows 版 的 PHP 5 安装 包 中 绑 定 的 都 是 3.23.x 


函数 的 返回 值 ， 如 果 成 功 则 返回 一 个 MySQL 连接 标识 ， 失 败 则 返回 False. 

该 函数 经 过 了 几 次 版 本 更 新 ， 详 细 情 况 如 下 说 明 。 

PHP 4.3.0 版 本 , 添加 了 client_flags 参数 ; PHP 4.2.0 版 添加 了 new_link 参数 .PHP 3.0.10 版 对 server 

添加 ":/path/to/socket" 路 径 的 支持 。PHP 3.0.0 版 对 server 添加 ":port" 可 选 端口 号 的 支持 。 

口 bool mysql_create_db(string database name[,resource link_identifier]) 函 数 。 调 用 该 函数 将 尝试 在 
指定 的 连接 标识 所 关联 的 服务 器 上 建立 一 个 新 数据 库 。 参数 database_name 为 想 要 创建 的 数据 
库 名 。 参 数 link identifier 为 MySQL 的 连接 标识 符 。 如 果 没 有 指定 ， 默 认 使 用 最 后 被 
mysql_connectO 打 开 的 连接 。 如 果 没 有 找到 该 连接 , 函数 会 尝试 调用 mysql_connect() 建 立 连接 
并 使 用 它 。 如 果 发 生意 外 ， 没 有 找到 连接 或 无 法 建立 连接 ， 系 统 发 出 E_WARNING 级 别 的 警 
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告 信息 。 返 回 值 ， 如 果 成 功 则 返回 Tme， 失 败 则 返回 Falses 

DO bool mysql_data_seek(resource result,int row_number ) 函 数 。 移 动 内 部 结果 的 指针 ,将 指定 的 结果 
标识 result 所 关联 的 MySQL 结果 内 部 的 行 指针 移动 到 row_number 所 指定 的 行 号 .row_number 
从 0 开始 。row_number 的 取 值 范围 从 0 到 Cmysql_num_rows-1) 。 但 是 如 果 结 果 集 为 空 

Cmysql_num_rows0==0) ， 即 数据 库 表 中 并 没有 任何 记录 ， 要 将 指针 移动 到 0 会 失败 并 发 出 
E WARNING 级 的 错误 ， 同 时 mysql_data_seek() 将 返回 False。 本 函数 的 参数 为 : result 为 返 
回 类 型 为 resource 的 结果 集 。 该 结果 集 从 mysql_query0) 的 调用 中 得 到 。row_number 为 想 要 设 
定 的 新 的 结果 集 指 针 的 行 数 。 函 数 返回 值 ， 如 果 成 功 则 返回 True， 失 败 则 返回 Falses 

口 string mysql db name(resource result,int row[,mixed field]) 函数 。 调 用 该 函数 将 取得 
mysql_list_dbs(0) 函 数 调用 所 返回 的 数据 库 名 。 参 数 result 为 mysql_list_dbs() 调 用 所 返回 的 结果 
指针 。row 为 结果 集中 的 行 号 。field 为 某 一 个 字段 名 。 此 函数 的 返回 值 ， 如 果 成 功 则 返回 数 
据 库 名 ， 失 败 返 回 False。 如 果 返 回 了 False， 用 mysql_error() 来 判断 错误 的 种 类 。 

口 resource mysql db guery(string database,string query[,resource link_identifier]) 函 数 。 此 函数 发 送 
一 条 MySQL 查询 。 根 据 查 询 结果 返回 一 个 MySQL 结果 资源 号 ， 出 错时 返回 False。 本 函数 
会 对 INSERT (插入 ) 、UPDATE (更 新 ) 、DELETE GWR) 3 项 查询 返回 True/False 来 指 
示 成 功 或 失败 。mysql_db_query() 选 择 一 个 数据 库 并 在 其 上 执行 查询 。 如 果 没 有 提供 可 选 的 连 
接 标 识 ， 本 函数 会 去 找 一 个 到 MySQL 服务 器 的 已 打开 的 连接 ， 如 果 找 不 到 已 打开 连接 则 会 
尝试 无 参数 调用 mysql_connect() 来 建立 一 个 。 

注意 : 此 函数 不 会 切换 回 先前 连接 到 的 数据 库 。 换 名 话说， 不 能 用 此 函数 临时 在 另 一 个 数据 库 上 执行 
sql 查询 , 只 能 手工 切换 回来 。 强烈 建议 用 户 在 sql 查询 中 使 用 database.table 语法 来 蔡 代 此 函数 。 
É PHP4.0.6 起 不 提倡 使 用 此 函数 。 不 要 用 此 函数 ， 用 mysql_select_db() 和 mysql_query() 来 替代 。 


口 bool mysql_drop_db(string database namef,resource link_identifier]) 函 数 。 丢 弃 (删除 ) 一 个 
MySQL 数据 库 。mysql_drop_db(0) 尝 试 丢弃 (删除 ) 指定 连接 标识 所 关联 的 服务 器 上 的 整个 数 
据 库 。 如 果 成 功 则 返回 True， 失 败 则 返回 False。 为 向 下 兼容 也 可 以 用 mysql_drop_db() 函 数 ， 
但 不 要 这 样 做 。 
注意 : 不 提倡 使 用 mysql_drop_db(0) 函 数 来 删除 数据 库 。 最 好 用 mysql_query() 提 交 一 条 SQL DROP 
DATABASE 语句 来 替代 。 


警告 : 如果 MySQL 扩展 库 是 基于 MySQL4.x 客户 端 库 建 立 的 ， 则 本 函数 不 可 用 。 


口 int mysql_errno([resource link_identifier]) 函 数 。 返 回 上 一 个 MySQL 操作 中 的 错误 信息 的 数字 
编码 。 如 果 没 有 出 错 则 返回 0. 从 MySQL 数据 库 后 端 来 的 错误 不 再 发 出 警告 , 要 用 mysql_errno() 
来 提取 错误 代码 。 
注意 : 本 函数 仅 返回 最 近 一 次 MySQL 函数 的 执行 (不 包括 mysql_error() 和 mysql_errno() ) 的 错误 代 
码 ， 因 此 如 果 要 使 用 此 函数 ， 确 保 在 调用 另 一 个 MySQL 函数 之 前 检查 它 的 值 。 如 果 指 定 了 可 
选 参数 则 用 给 定 的 连接 提取 错误 代码 。 否 则 使 用 上 一 个 打开 的 连接 。 


O string mysql_error([resource link identifier]) 函 数 。 返 回 上 一 个 MySQL 操作 产生 的 文本 错误 信 
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息 。 如 果 没 有 出 错 则 返回 " "( 空 字符 串 ) 。 如 果 没 有 指定 连接 资源 号 ， 则 使 用 上 一 个 成 功 打 
开 的 连接 从 MySQL 服务 器 提取 错误 信息 。 从 MySQL 数据 库 后 端 来 的 错误 不 再 发 出 警告 ， 要 
用 mysql_error() 来 提取 错误 文本 。 
注意 : 和 mysql_errmno() 函 数 一 样 ， 本 函数 仅 返 回 最近 一 次 MySQL 函数 的 执行 ( 不 包括 mysql_error() 
和 mysql_ermo0 的 错误 文本 ,因此 如 果 要 使 用 此 函数 ,确保 在 调用 另 一 个 MySQL 函数 之 前 检查 
它 的 值 。 


口 string mysql escape_string(string unescaped_string) 函 数 。 本 函数 将 unescaped_string 转 义 ， 使 之 
可 以 安全 用 于 mysql_query()。 


注意 : mysql_escape_string() 函 数 并 不 转 义 “%” 和 “?”。 


口 array mysql_fetch_array(resource result[,int result_type]) 函 数 。 返 回 根据 从 结果 集 取得 的 行 生 成 
的 数组 ， 如 果 没 有 更 多 行 则 返回 False。mysql_fetch_array() 是 mysql_fetch_row() 的 扩展 版 本 。 
除了 将 数据 以 数字 索引 方式 储存 在 数组 中 之 外 ， 还 可 以 将 数据 作为 关联 索引 储存 ， 用 字段 名 
作为 键 名 。 
注意 : 如 果 结果 中 的 两 个 或 两 个 以 上 的 列 具有 相同 字段 名 ， 最 后 一 列 将 优先 。 要 访问 同名 的 其 他 列 ， 
必须 用 该 列 的 数字 索引 或 给 该 列 起 个 别名 。 对 有 别名 的 列 ， 不 能 再 用 原来 的 列 名 访问 其 内 容 。 
口 array mysql_fetch_assoc(resource result) 函 数 。 返 回 根 据 从 结果 集 取 得 的 行 生 成 的 关联 数组 ， 如 
果 没有 更 多 行 则 返回 Falses H mysql_fetch_assoc() 和 用 mysql_fetch_array() 加 上 第 2 个 可 选 参 
数 MySQL_ASSOC 的 结果 是 完全 相同 的 。 它 仅仅 返回 关联 数组 。 这 也 是 mysql_fetch_array() 
函数 初始 的 工作 方式 。 如 果 在 关联 索引 之 外 还 需要 数字 索引 ， 还 是 要 用 mysql_fetch_array()。 
注意 : 如 果 结 果 中 的 两 个 或 两 个 以 上 的 列 具有 相同 字段 名 ， 最 后 一 列 将 优先 。 要 访问 同名 的 其 他 列 ， 
要 么 用 mysql_fetch row() 来 取得 数字 索引 或 给 该 列 起 个 别名 。 参 见 mysql_fetch_array() 例 子 中 有 
关 别 名 说 明 。 
有 一 点 很 重要 必须 指出 ， 用 mysql_fetch_assoc() 并 不 明显 比 用 mysql_fetch_row() 慢 ， 而且 还 提供 了 
明显 更 多 的 值 。 
注意 : 本 函数 返回 的 字段 名 是 区 分 大 小 写 的 。 


口 object mysql_fetch_field(resource result[,int field_offset]) 函 数 。 从 结果 集中 取得 列 信息 并 作为 对 
象 返回 。 如 果 没 有 指定 字段 偏 移 量 ， 则 下 一 个 尚未 被 mysql_fetch_field() 取 得 的 字段 将 会 被 
提取 。 

对 象 的 属性 有 以 下 几 项 分 别 为 name 属性 为 列 名 、table 属性 为 该 列 所 在 的 表 名 、max_length 为 该 
列 最 大 长 度 、 如 果 该 列 不 能 为 NULL W not_null 属性 为 1、 如 果 该 列 是 primary key 则 primary key 属性 
1、 如 果 该 列 是 unique key 则 unigue key 属性 为 1、 如果 该 列 是 non-unique key 则 multiple key 为 1、 如 
果 该 列 是 numeric 则 numeric 为 1、 如 果 该 列 是 BLOB 则 blob 属性 为 1、type 属性 为 该 列 的 类 型 、 如 果 
该 列 是 无 符号 数 则 unsigned 属性 为 1、 如 果 该 列 是 zero-filled 则 zerofill 属性 为 1。 


注意 : 本 函数 返回 的 字段 名 是 区 分 大 小 写 的 。 


ua 


口 


口 
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array mysql_fetch_lengths(resource resulb 函 数 。 取 得 结果 集 result 中 每 个 输出 的 长 度 。 如 果 出 
错 返 回 Falses mysql_fetch lengths0 将 上 一 次 mysql_fetch_row0 ，mysql_fetch_array(0 和 
mysql_fetch_object() 所 返回 的 每 个 列 的 长 度 储存 到 一 个 数组 中 ， 偏 移 量 从 0 开始 。 

object mysql fetch_object(resource result) 函 数 。 从 结果 集 result 中 取得 一 行 作为 对 象 。 如 果 没 
有 更 多 行 则 返回 False。mysql_fetch_object0 函 数 和 mysql_fetch_array() 函 数 有 一 定 的 类 似 ， 只 
有 一 点 区 别 就 是 返回 的 是 一 个 对 象 而 不 是 数组 。 间接 的 也 意味 着 只 能 通过 字段 名 来 访问 数组 ， 
而 不 是 偏 移 量 (数字 是 合法 的 属性 名 〉。 


注意 : 本 函数 返回 的 字段 名 是 区 分 大 小 写 的 。 


口 


array mysql_fetch_row(resource result) 函 数 。 返 回 根据 所 取得 的 行 生成 的 数组 ， 如 果 没 有 更 多 
行 则 返回 False。mysql_fetch_row0 从 和 指定 的 结果 标识 关联 的 结果 集中 取得 一 行 数据 并 作为 
数组 返回 。 每 个 结果 的 列 储存 在 一 个 数组 的 单元 中 ， 偏 移 量 从 0 开始 。 依 次 调用 
mysql_fetch_row() 将 返回 结果 集中 的 下 一 行 ， 如 果 没 有 更 多 行 则 返回 False。 


注意 : 本 函数 返回 的 字段 名 是 区 分 大 小 写 的 。 


口 


口 
口 


string mysql_field_flags(resource result,int field_offseb) 函 数 。 该 函数 返回 指定 字段 的 字段 标志 。 
每 个 标志 都 用 一 个 单词 表示 ， 之 间 用 一 个 空格 分 开 ， 因 此 可 以 用 explode() 把 字符 串 分 割 到 数 
组 中 。 

int mysql_field_len(resource resulbint field_offseb 函 数 。 返 回 指定 字段 的 长 度 。 

string mysql_field_name(resource result,int field_index) 函 数 。 该 函数 返回 指定 字段 索引 的 字段 
名 。 其 中 result 参数 必须 是 一 个 合法 的 结果 标识 符 ，field_index 是 该 字段 的 数字 偏 移 量 。 


注意 : field_index 从 0 开始 。 如 第 3 个 字段 的 索引 值 其 实 是 2， 第 4 个 字段 的 索引 值 是 3， 以 此 类 推 。 


口 


本 函数 返回 的 字段 名 是 区 分 大 小 写 的 。 


int mysql_field_seek(resource result,int field_offseb 函 数 。 用 指定 的 字段 偏 移 量 检索 。 如 果 下 一 
个 mysql_fetch_field0 的 调用 不 包括 字段 偏 移 量 ， 则 会 返回 本 次 mysql_field_seek() 中 指定 的 偏 
移 量 的 字段 。 

string mysql_field_table(resource result,int field_offseb) 函 数 。 取 得 指定 字段 所 在 的 表 名 。 

string mysql_field_type(resource result,int field_offset) 函 数 。 取 得 结果 集中 指定 字段 的 类 型 。 该 
函数 和 mysql_field_name() 函 数 相似 。 参 数 完全 相同 ， 但 该 函数 返回 的 是 字段 类 型 而 不 是 字段 
名 。 字 段 类 型 有 “int”、“real”、“string”、“blob” 以 及 其 他 类 型 。 

bool mysql_free_result(resource resulb 函 数 。 释 放 结 果 标识 符 result 所 占用 的 内 存 。 该 函数 仅 需 
要 在 考虑 到 返回 很 大 的 结果 集 时 会 占用 多 少 内 存 时 调用 。 在 脚本 结束 后 所 有 关联 的 内 存 都 会 
被 自动 释放 。 如 果 成 功 释 放 内 存 则 返回 True， 失 败 则 返回 Falses 
string mysql_get_client_info0) 函 数 。 调 用 该 函数 将 取得 MySQL 客户 端 信息 ， 函 数 返 回 一 个 字 
符 串 ， 该 字符 串 代 表 了 MySQL 的 版 本 。 

string mysql_get_host info([resource link_identifier]) 函 数 。 取 得 MySQL 主机 信息 。 
mysql_get_host_info() 返 回 一 个 字符 串 说 明了 连接 link_identifier 所 使 用 的 连接 方式 ， 包 括 服务 
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器 的 主机 名 。 如 果 省 略 link_identifier， 则 使 用 上 一 个 打开 的 连接 。 
口 intmysql_ get_proto_info([resource link identifier]) 函 数 。mysql_get_proto_info(0) 返 回 link_identifier 
所 使 用 的 协议 版 本 。 如 果 省 略 link identifier， 则 使 用 上 一 个 打开 的 连接 。 
口 string mysql_get_server info([resource link_identifier]) 函 数 。 该 函数 返回 link identifier 所 使 用 的 
服务 器 版 本 。 如 果 省 略 link_identifier， 则 使 用 上 一 个 打开 的 连接 。 
O string mysql_info([resource link_identifier]) 函 数 。mysql_info0 返 回 通过 给 定 的 link_identifier 所 
进行 的 最 新 一 条 查询 的 详细 信息 。 如 果 没 有 指定 link_identifier， 则 假定 为 上 一 个 打开 的 连接 。 
mysql_info() 对 以 下 列 出 的 所 有 语句 返回 一 个 字符 串 。 对 于 其 他 任何 语句 返回 Falses 字符 串 的 格式 
取决 于 给 出 的 语句 。 起 作用 的 语句 如 下 所 示 : 
INSERT INTO SELECT 插入 语句 ; 
INSERT INTO VALUES 插入 语句 ; 
LOAD DATA INFILE 载 入 数据 语句 ; 
ALTER TABLE 改变 表 结 构 语 句 ; 
UPDATE 更 新 记录 语句 。 
O int mysql_insert_id([resource link_identifier]) 函 数 。 调 用 该 函数 将 返回 给 定 的 link_identifier 中 上 
一 步 INSERT 查询 中 产生 的 AUTO_INCREMENT 的 ID 号。 如 果 没 有 指定 link_identifier， 则 
使 用 上 一 个 打开 的 连接 。 如 果 上 一 查询 没有 产生 AUTO_INCREMENT 的 值 , 则 mysql_insert_id0 
将 会 返回 0。 如 果 需 要 保存 该 值 以 后 使 用 ， 要 确保 在 产生 了 值 的 查询 后 立即 调用 
mysql_insert_id() 函 数 。 
注意 : MySQL 中 的 SQL 函数 LAST_INSERT_ID() 总 是 保存 着 最 新 产生 的 AUTO_INCREMENT 值 ， 
并 且 不 会 在 查询 语句 之 间 被 重 置 。 
警告 : mysql_insert_id() 将 MySQL 内 部 的 C API 函数 mysql_insert_id() 的 返回 值 转换 成 long ( PHP 中 
命名 为 int) 。 如 果 AUTO_INCREMENT 的 列 的 类 型 是 BIGINT， 则 mysql_insert_id() 返 回 的 值 
将 可 能 不 正确 。 可 以 在 SQL 查询 中 用 MySQL 内 部 的 SQL 函数 LAST INSERT ID0 来 替代 以 取 
得 上 一 步 INSERT 操作 产生 的 ID. 


D resource mysql_list_dbs([resource link_identifier]) 函 数 。 调 用 该 函数 将 返回 一 个 结果 指针 ， 包 含 
了 当前 MySQL 进程 中 所 有 可 用 的 数据 库 。 用 mysql_tablename() 函 数 来 遍历 此 结果 指针 , 或 者 
任何 使 用 结果 表 的 函数 。 

口 resource mysql list fields(string database name,string table namef,resource link_identifier]) 函 数 。 
调用 该 函数 取得 给 定 table name 表 名 的 信息 。 参 数 是 数据 库 名 和 表 名 。 返 回 一 个 结果 指针 ， 
可 以 用 于 mysql_field_flags0)，mysql_field_len0，mysql_field_name(0 和 mysql_field_typeO)。 

注意 : 此 函数 已 过 时 。 最 好 用 mysql_query() 来 发 出 一 条 SHOW COLUMNS FROM table [LIKE mame'] 
的 SQL 语句 来 代替 。 

口 resource mysql_list_processes([resource link_identifier]) 函 数 。mysql_list_ processes0 返 回 一 个 结 
果 指 针 ， 说 明了 当前 服务 器 的 线程 。 

口 resource mysql list_tables() 函 数 。 该 函数 接受 一 个 数据 库 名 并 返回 和 mysql_query0 函 数 很 相似 
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的 一 个 结果 指针 。 用 mysql_tablename() 函 数 来 遍历 此 结果 指针 ， 或 者 任何 使 用 结果 表 的 函数 。 
database 参数 是 需要 被 取得 其 中 的 表 名 的 数据 库 名 。 如 果 失 败 函 数 返回 False。 


注意 ; 该 函数 已 经 被 删除 了 ， 请 不 要 再 使 用 该 函数 。 可 以 用 命令 mysql_query 发 送 一 条 SQL 指令 
SHOW TABLES FROM DATABASE 来 实现 该 函数 的 功能 。 


O int mysql_num fields(resource result) 函 数 。 调 用 该 函数 将 会 返回 结果 集中 字段 的 数目 。 

O int mysql_num_rows(resource result) 函 数 。 调 用 此 函数 将 会 返回 结果 集中 行 的 数目 。 此 命令 仅 
对 SELECT 语句 有 效 。 要 取得 被 INSERT 插入 、UPDATE 更 新 或 者 DELETE 删除 查询 所 影响 
到 的 行 的 数目 ， 用 mysql_affected_rows() 函 数 。 

口 resource mysql pconnect(string server[,string username[,string password[,int client_flags]]])) 函 数 。 
如 果 成 功 则 返回 一 个 正确 的 MySQL 持久 连接 标识 符 ， 出 错 则 返回 False。mysql_pconnect() 函 
数 建立 一 个 到 MySQL 服务 器 的 连接 。 如 果 没 有 提供 可 选 参数 ， 则 使 用 如 下 默认 值 : 
SerVver='localhost:3306'，username= 服 务 器 进程 所 有 者 的 用 户 名 ，password= 空 密码 。client_flags 
参数 可 以 是 以 下 常量 的 组 合 : MySQL_CLIENT_COMPRESS, MySQL_CLIENT_IGNORE_ 
SPACE 或 者 MySQL_CLIENT_INTERACTIVE 。server 参数 也 可 以 包括 端口 号 ， 例 如 
"hostname:port"， 或 者 是 本 机 套 接 字 的 路 径 ， 例 如 "/path/to/socket"。 


注意 : 对 ":port" 端 口 的 支持 是 PHP 的 3.0B4 版 添加 的 。 对 本 机 套 接 字 的 路 径 ":/path/to/socket" 的 支持 是 
PHP 3.0.10 版 添加 的 。 可 选 参数 client_flags 自 PHP4.3.0 版 起 作用 。 此 种 连接 称 为 “持久 的 ”。 


mysql_pconnect0 和 mysql_connect() 非 常 相似 ， 但 有 两 个 主要 区 别 。 

首先 ， 当 连接 的 时 候 本 函数 将 先 尝试 寻找 一 个 在 同一 个 主机 上 用 同样 的 用 户 名 和 密码 已 经 打开 的 
(持久 ) 连接 ， 如 果 找 到 ， 则 返回 此 连接 标识 而 不 打开 新 连接 。 

其 次 ， 当 脚本 执行 完毕 后 到 SQL 服务 器 的 连接 不 会 被 关闭 ， 此 连接 将 保持 打开 以 备 以 后 使 用 
(mysql_close0 不 会 关闭 由 mysql_pconnect() 建立 的 连接 ) 。 
注意 : 此 种 连接 仅 能 用 于 模块 版 本 的 PHP。 


口 ”bool mysql_ping([resource link_identifier ]) 函 数 。mysql_pingO) 函 数 检查 到 服务 器 的 连接 是 否 正 
常 。 如 果断 开 ， 则 自动 尝试 连接 。 本 函数 可 用 于 空闲 很 久 的 脚本 来 检查 服务 器 是 否 关闭 了 连 
接 ， 如 果 有 必要 则 重新 连接 上 。 如 果 到 服务 器 的 连接 可 用 则 mysql pingkel True, FWA 
回 False。 

D resource mysql_query(string query[,resource link_identifier]) 函 数 。mysql_query0) 向 与 指定 的 连接 
标识 符 关 联 的 服务 器 中 的 当前 活动 数据 库 发 送 一 条 查询 。 如 果 没 有 指定 link_identifier， 则 使 
用 上 一 个 打开 的 连接 。 如 果 没有 打开 的 连接 ， 本 函数 会 尝试 无 参数 调用 mysql_connect() 函 数 
来 建立 一 个 连接 并 使 用 。 查 询 结果 会 被 缓存 。 

注意 : 查询 字符 串 不 应 以 分 号 结束 。 


另外 ，mysql_query0 仅 对 SELECT，SHOW，EXPLAIN 或 DESCRIBE 语句 返回 一 个 资源 标识 符 ， 
如 果 查 询 执行 不 正确 则 返回 False。 对 于 其 他 类 型 的 SQL 语句 ，mysql_query() 在 执行 成 功 时 返回 True, 
出 错时 返回 False。 非 False 的 返回 值 意味 着 查询 是 合法 的 并 能 够 被 服务 器 执行 。 这 并 不 说 明 任何 有 关 
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影响 到 的 或 返回 的 行 数 。 很 有 可 能 一 条 查询 执行 成 功 了 但 并 未 影响 到 或 并 未 返回 任何 行 。 
如 果 没 有 权限 访问 查询 语句 中 引用 的 表 时 ，mysql_query0 也 会 返回 False。 
假定 查询 成 功 ， 可 以 调用 mysql_num_rows() 来 查看 对 应 于 SELECT 语句 返回 了 多 少 行 ， 或 者 调用 
mysql_affected_rows() 来 查看 对 应 于 DELETE, INSERT, REPLACE 3È UPDATE 语句 影响 到 了 多 少 行 。 
仅 对 SELECT, SHOW, DESCRIBE 或 EXPLAIN 语句 mysql_query() 才 会 返回 一 个 新 的 结果 标识 
符 ， 可 以 将 其 传递 给 mysql_fetch_array0 和 其 他 处 理 结果 表 的 函数 。 处 理 完结 果 集 后 可 以 通过 调用 
mysql_free_result() 来 释放 与 之 关联 的 资源 ， 尽 管 脚本 执行 完毕 后 会 自动 释放 内 存 。 
口 string mysql real escape string(string unescaped_string[,resource link identifier]) 函 数 。 本 函数 将 
unescaped_string 中 的 特殊 字符 转 义 ， 并 计 及 连接 的 当前 字符 集 ， 因 此 可 以 安全 用 于 
mysql_query()。 


注意 : mysql_real_escape_string() 并 不 转 义 “%” 和 “”。 


O mixed mysql_result(resource result,int row[,mixed field]) 函 数 。 调 用 该 函数 将 返回 MySQL 结果 

集中 一 个 单元 的 内 容 。 字 段 参 数 可 以 是 字段 的 偏 移 量 或 者 字段 名 ， 或 者 是 字段 表 点 字段 名 

(tablename.fieldname ) 。 如 果 给 列 起 了 别名 〈'select foo as bar from...) ， 则 用 别名 替代 列 名 。 

当 作 用 于 很 大 的 结果 集 时 ， 应 该 考虑 使 用 能 够 取得 整 行 的 函数 〈 在 下 边 指 出 ) 。 这 些 函 数 在 一 次 

函数 调用 中 返回 了 多 个 单元 的 内 容 ， 比 mysql_result() 快 得 多 。 此 外 注意 在 字段 参数 中 指定 数字 偏 移 量 
比 指定 字段 名 或 者 tablename.fieldname 要 快 得 多 。 


注意 : 调用 mysql_result0 不 能 和 其 他 处 理 结果 集 的 函数 混合 调用 。 


O bool mysgl select db(string database namef,resource link_identifier]) 函 数 。 该 函数 将 选择 指定 的 
MySQL 数据 库 。 如 果 成 功 则 返回 True， 失 败 则 返回 False。mysql_select_db() 设 定 与 指定 的 连 
接 标 识 符 所 关联 的 服务 器 上 的 当前 激活 数据 库 。 如 果 没 有 指定 连接 标识 符 ， 则 使 用 上 一 个 
打开 的 连接 。 如 果 没有 打开 的 连接 ， 本 函数 将 无 参数 调用 mysql_connect() 来 尝试 打开 一 个 并 
使 用 。 

O string mysql_stat([resource link_identifier]) 函 数 。mysql_stat() 返 回 当前 服务 器 状态 。 


注意 : mysql_stat() 目 前 只 返回 uptime, threads, queries, open tables, flush tables 和 queries per second. 
要 得 到 其 他 状态 变量 的 完整 列表 ， 只 能 使 用 SQL 命令 SHOW STATUS。 取 得 当前 系统 状态 。 


O string mysql_tablename(resource result,int iD) 函数。mysql_tablename(O) 接 受 mysql_list_tables() 返 回 
的 结果 指针 以 及 一 个 整数 索引 作为 参数 并 返回 表 名 。 可 以 用 mysql_num_rows0 函 数 来 判断 结 
果 指 针 中 的 表 的 数目 。 用 mysql_tablename() 函 数 来 遍历 此 结果 指针 ， 或 者 任何 处 理 结果 表 的 
函数 。 

口 int mysql_thread_id([resource link_identifier]) 函 数 。mysql_thread_id() 返 回 当前 线程 的 ID。 如 果 
连接 丢失 了 并 用 mysql_ping0 重 新 连接 上 , 线程 ID 会 改变 。 这 意味 着 不 能 取得 线程 的 ID 后 保 
存 起 来 备用 。 当 需要 的 时 候 再 去 获取 之 。 

口 resource mysql_unbuffered_query(string query[,resource link identifier) 函 数 。 该 函数 向 MySQL 
发 送 一 条 SQL 查询 query， 但 不 像 mysql_query0 那 样 自动 获取 并 缓存 结果 集 。 一 方面 ， 这 在 
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处 理 很 大 的 结果 集 时 会 节省 可 观 的 内 存 。 另 一 方面 ， 可 以 在 获取 第 一 行 后 立即 对 结果 集 进 行 
操作 ， 而 不 用 等 到 整个 SQL 语句 都 执行 完毕 。 当 使 用 多 个 数据 库 连 接 时 ， 必 须 指定 可 选 参数 
link_identifier。 
PHP 中 的 MySQL 函数 就 为 读者 介绍 到 这 里 。 实 际 上 这 些 函数 中 ， 有 一 些 是 不 太 常 用 的 。 读 者 不 
必 完 全 掌握 ， 如 果 在 实际 操作 中 见 到 这 样 的 函数 ， 知 道 它们 是 如 何 起 作用 的 就 行 了 。 但 对 于 一 些 常 用 
的 函数 则 必须 熟练 掌握 ， 因 为 熟练 掌握 其 中 的 常用 函数 是 学 好 数据 库 的 前 提 。 


14.3 数据库 操作 


这 一 节 ， 就 来 学 习 实际 对 数据 库 的 操作 。 内 容 包括 如 何 连接 数据 服务 器 ， 如 何 显示 目前 的 数据 库 ， 
如 何 创建 一 个 数据 库 ， 如 何 连接 已 经 存在 的 库 ， 如 何在 库 中 创建 表 及 如 何在 表 中 插入 记录 等 。 


14.3.1 连接 MySQL 服务 器 


所 有 对 MySQL 数据 库 的 操作 都 要 在 主机 提供 MySQL 服务 的 前 提 下 进行 。 连接 提供 了 此 项 服务 的 
主机 是 进行 数据 库 操作 的 前 提 。 所 以 在 进行 数据 库 操作 前 必须 要 连接 到 MySQL 服务 器 。 

在 PHP 编程 环境 下 要 连接 到 MySQL 服务 器 , 需要 使 用 函数 mysql_connect()。 该 函数 有 3 个 参数 ， 
第 1 个 参数 为 主机 名 ; 第 2 个 参数 为 用 户 名 ; 第 3 个 参数 为 该 用 户 的 密码 。 此 函数 连接 到 MySQL 服 
务 器 ， 如 果 成 功 返 回 True， 反 之 返回 False。 

下 面 通过 一 个 实例 来 说 明 ， 如 何 使 用 mysql_connect() 函 数 来 连接 到 MySQL 服务 器 。 


<html> 

<head> 

<title> 连 接 MySQL 服务 器 </title> 

</head> 

<body> 

<?php 

$db_host=localhost; /MySQL 服务 器 名 
$db_user=root; /MySQL 用 户 名 
$db_pass=""; /MySQL 用 户 对 应 密码 
/使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 返 回 相应 信息 
$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
echo "成 功 连接 到 服务 器 "; // 如 果 连 接 成 功 显示 信息 

?> 

</body> 

</html> 


保存 以 上 代码 为 “14-1.php”。 然 后 开启 APACHE 服务 及 MySQL 服务 本章 实例 均 需 要 两 种 服 
务 共 同 支持 ， 下 同 ) ， 在 PHP 执行 环境 下 运行 该 文件 ， 其 执行 结果 将 会 如 图 14.1 所 示 。 

上 面 代码 中 mysql_connect0 的 作用 是 连接 到 MySQL 服务器, 它 带 有 3 个 string 参数 。 第 1 个 参数 
指 主机 名 ， 第 2 个 参数 是 用 户 名 ， 第 3 个 参数 是 用 户 密码 。 这 些 信息 都 由 MySQL 服务 提供 者 提供 。 
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后 面 的 or dieO 指 如 果 不 能 正确 连接 MySQL 服务 器 的 返回 信息 。 


第 2 句 很 明显 是 输出 了 一 名 连接 成 功 的 信息 。 EECEEEDETEEEOEOL CGI 
AT bAa Iona WA zi u D v D AI 
执行 以 上 操作 ， 如 果 正 确 无 误 就 能 正确 连接 到 zre smo sto me mo IAA 
wa = y 成 功 连 接 到 服务 器 
MySQL 服务 器 了 。 其 执行 结果 如 图 14.1 所 示 。 如 果 关 - 可 
闭 MySQL 服务 就 会 导致 无 法 连接 到 服务 器 则 程序 会 输 。” == WE 
出 像 这 样 的 信息 : 图 14.1 连接 MySQL 服务 器 执行 结果 


不 能 连接 到 服务 器 Can't connect to MySQL server on 'localhost' (10061). 
关于 如 何 连 接 到 服务 器 就 先 介 绍 到 这 里 。 


14.3.2 ”连接 到 服务 器 并 显示 可 用 数据 库 


连接 到 MySQL 服务 器 上 后 ， 下 一 步 就 是 了 解 当 前 数据 库 的 状况 。 因 为 只 有 了 解 服务 器 上 的 可 用 
数据 库 信 息 ， 才 能 使 用 户 决 定 下 一 步 要 如 何 操作 。 下 面 讲 解 如 何 显示 可 用 的 数据 库 。 要 显示 服务 器 上 
的 数据 库 情 况 使 用 mysql_list_dbs() 函 数 。 该 函数 有 一 个 参数 ， 此 参数 为 已 经 建立 的 服务 器 连接 。 

下 面 通过 一 个 实例 来 说 明 如 何 使 用 mysql_list_dbs() 函 数 来 显示 服务 器 上 的 可 用 数据 库 。 具 体内 容 
请 参看 以 下 代码 : 


<html> 

<head> 

<title> 显 示 数 据 库 </title> 

</head> 

<body> 

<?php 

$db_host=localhost; /MySQL 服务 器 名 

$db_user=root; /MySQL 用 户 名 

$db_pass=""; /MySQL 用 户 对 应 密码 

/使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 返 回 相 应 信息 

$link-mysg! connect($db host,$db user,$db pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
$db_listzmysql_list_dbs($link); /显示 数据 库 ， 参 数 为 上 一 步 的 服务 器 连接 
while($db=mysql_fetch_object($db list) // 通 过 循环 遍历 返回 的 结果 集 


echo $db->Database:; /显示 数据 库 名 ， 注 意 大 小 写 
echo "<p>"; 
} 
?> 
</body> 
</html> 
保存 以 上 代码 为 “14-2.php”。 然 后 在 PHP 
执行 环境 下 执行 该 文件 ， 执 行 结 果 将 会 如 图 14.2 aysal - 


由 于 此 时 服务 器 上 只 有 两 个 数据 库 ，MySQL 
库 与 TEST 库 ， 所 以 显示 两 条 记录 。 


IE 


EE CO Oe 


142 显示 数据 库 执行 结果 
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1433 在 服务 器 上 创建 新 的 数据 库 


对 数据 库 进行 操作 时 ， 系 统 提供 的 数据 库 通 常 是 有 限 的 ， 所 以 需要 在 服务 器 上 建立 新 的 数据 库 。 
下 面 介 绍 如 何在 服务 器 上 创建 一 个 新 的 数据 库 。 要 创建 新 的 数据 库 ， 要 使 用 mysql_create_db() 函 数 。 
mysql_create_db() 函 数 的 使 用 格式 如 下 所 示 : 


mysql_creaet_ db(string database name[,resource link identifier)) 


该 函数 包含 两 个 参数 ， 第 1 个 参数 为 要 创建 的 数据 库 名 ， 第 2 个 参数 为 可 选 参数 ， 为 已 经 连接 的 
服务 器 的 连接 标识 。 
下 面 通过 一 个 实例 来 介绍 如 何 使 用 该 函数 在 服务 器 上 创建 新 的 数据 库 。 


<html> 

<head> 

<title> 创 建新 的 数据 库 </title> 

</head> 

<body> 

<?php 

$db host-localhost; /MySQL 服务 器 名 
$db_user=root; /MySQL 用 户 名 
$db_pass=""; /MySQL 用 户 对 应 密码 
/使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 返 回 相应 信息 
$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 


说 mysql_create_db("database1",$link)) /使 用 mysql_create_db() 创 建 数据 库 

echo "数据 库 创 建成 功 "; // 如 果 创 建成 功 显示 信息 

echo "<p>"; 

echo "当前 服务 器 上 的 所 有 数据 库 为 :"; 

echo "<p>"; 

$db_list=mysql_list_dbs($link); /显示 数据 库 

while($db=mysql_fetch_object($db list) // 通 过 循环 遍历 返回 的 结果 集 
echo $db->Database; /显示 数据 库 名 ， 注 意 大 小 写 
echo "<p>"; 

} 

?> 

</body> 

</html> 


ini 
| 文件 四 


REFERI 
当前 服务 器 上 的 所 有 数据 库 为 ， 


databasel 


RAV SEV W IAV WDY 


保存 以 上 代码 为 “14-3.php”， 然 后 在 PHP 执行 环 
境 下 运行 该 文件 ， 其 执行 结果 如 图 14.3 所 示 。 

由 于 该 函数 已 经 废弃 ， 所 以 建议 在 创建 数据 库 时 使 
用 mysql_query0 来 发 送 一 条 sql 语句 达到 创建 数据 库 的 
目的 。 具 体 作法 请 参看 如 下 代码 : 

<html> az OI T Dinter 


SR 图 143 ”创建 新 的 数据 库 执行 结果 


zi 
Z] 


从 以 上 两 个 例子 及 执行 结果 可 以 看 出 ， 使 用 ECEE 下 [下 
SQL 语句 同样 能 达到 创建 数据 库 的 目的 。 要 注意 ee ee a me EJ 
的 是 创建 数据 库 的 SQL 语句 的 语法 : 为 “CREATE i E 
DATABASE” 后 面 加 上 想 要 创建 的 数据 库 名 称 即 A 
可 。 然 后 使 用 mysql_query() 来 发 送 SQL 语句 。 来 
达到 创建 数据 库 的 目的 。 msa 
14.3.4 ”在 选 定数 据 库 里 创建 表 mi — 


g 
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<title> 使 用 SQL 语句 创建 新 的 数据 库 </title> 


</head> 
<body> 
<?php 
$db_host=localhost; /MySQL 服务 器 名 
/MySQL 用 户 名 
/MySQL 用 户 对 应 密码 


// 使 用 mysql ' connect BAHRA RETER, 如 果 出 错 返回 相应 信息 
$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 


$sql="CREATE DATABASE data2"; /创建 数据 库 的 SQL 语句 

if(mysql_query($sql,$link)) /发 送 SQL 语句 

echo "数据 库 创建 成 功 "; // 如 果 创 建成 功 显示 信息 

echo "<p>"; 

echo "当前 前 服务 器 上 的 所 有 数据 库 为 : 加 

echo "<p>"; 

$db list=mysql_list_dbs($link); /显示 数据 库 

while($db=mysql_fetch_object($db_ list) // 通 过 循环 遍历 返回 的 结果 集 
echo $db->Database; /显示 数据 库 名 ， 注 意 大 小 写 
echo "<p>"; 

?> 

</body> 

</html> 


把 以 上 代码 保存 为 “14-4.php”， 然 后 在 PHP 执行 环境 下 运行 该 文件 ， 其 执行 结果 如 图 14.4 所 示 。 


图 14.4 使 用 语句 创建 新 的 数据 库 执行 结果 
通过 前 而 的 介绍 读者 能 了 解 到 , 表 是 数据 库 的 WA i T 


主要 构成 元 素 。 有 了 数据 库 还 必须 有 特定 的 表 才能 发 挥 作用 ， 因 为 基本 上 所 有 的 数据 库 操作 都 是 在 表 
进行 的 。 这 一 小 节 就 来 介绍 如 何在 数据 库 里 创建 表 。 


注意 : 服务 器 上 MySQL 数据 库 是 运行 MySQL 服务 的 关键 库 ， 不 要 尝试 对 该 库 进 行 操作 ， 更 不 要 对 里 


面 的 表 进 行 添加 、 删 除 、 修 改 等 操作 。 


要 想 在 数据 库 中 创建 表 ， 要 使 用 mysql_query0 函 数 发 送 SQL 语句 来 实现 。 
创建 表 的 SQL 语句 的 语法 如 下 所 示 : 


create table table name (column name data 无 效 {identity |nulijnot null}, +++) 
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其 中 参数 table name 为 表 名 和 column name 为 列 名 即 字段 名 必须 满足 用 户 数据 库 中 的 识别 器 
Cidentifier) 的 要 求 ， 参 数 data 无 效 是 一 个 标准 的 SQL 类 型 或 由 用 户 数据 库 提供 的 类 型 。 用 户 要 使 用 
non-null 从 句 为 各 字段 输入 数据 。 
create table 还 有 一 些 其 他 选项 , 如 创建 临时 表 和 使 用 select 子 句 从 其 他 的 表 中 读 取 某 些 字段 组 成 新 
表 等 。 还 有 , 在 创建 表 是 可 用 PRIMARY KEY, KEY, INDEX 等 标识 符 设 定 某 些 字段 为 主键 或 索引 等 。 
书写 上 要 注意 : 
在 一 对 圆 括号 里 的 列 出 完整 的 字段 清单 。 
字段 名 间 用 去 号 隔 开 。 
字段 名 间 的 逗号 后 要 加 一 个 空格 。 
最 后 一 个 字段 名 后 不 用 逗号 。 
所 有 的 SQL 陈述 都 以 分 号 “;” 结 束 。 
如 下 面 的 这 一 句 : 


$sql="create table table1(id int(5) not null auto_increment primary key, name varchar(12) not null,mail 
varchar(30) not null,phone varchar(14) not null,address varchar(30) not null)"; 


下 面 的 SQL 语句 定义 了 一 个 表 ， 表 有 这 样 儿 个 字段 ;: id、name、mail、phone、address 等 。 并 且 
还 为 每 个 字段 指定 了 类 型 ,并 且 其 中 的 这 字段 有 primart 属 性 和 auto_increment 这 样 的 属性 .其 中 primary 
指明 该 字段 为 表 的 主键 (有 唯一 值 ); 而 auto_increment 则 指明 这 个 字段 是 自动 增加 的 。 

下 面 ， 就 使 用 该 SQL 语句 在 test 库 中 创建 一 个 名 为 testl 的 表 。 具 体内 容 参 看 以 下 代码 : 


<html> 

<head> 

<title> 在 库 中 创建 新 表 </title> 

</head> 

<body> 

<?php 

$db_host=localhost; /MySQL 服务 器 名 

$db_user=root; /MySQL 用 户 名 

$db_pass=""; /MySQL 用 户 对 应 密码 

$db_name="test"; // 要 操作 的 数据 库 

/使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 返 回 相应 信息 
$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
mysql_select_db($db_name,$link); // 选 择 相应 的 数据 库 ， 这 里 选择 test 库 

/下 面 的 $sql 就 为 创建 表 的 SQL 语句 

$sql="create table test1(id int(5) not null auto_increment primary key, name varchar(12) not null,mail varchar(30) 
not null,phone varchar(14) not null,address varchar(30) not null)"; 


OOOODO 


if(mysql_query($sql,$link)) NBA SQL 语句 执行 创建 表 的 操作 
echo " 表 test1 创建 成 功 "; // 如 果 创 建成 功 显示 信息 

echo "<p>"; 

echo "当前 ".$db_name." 上 的 所 有 数据 表 为 : "; 

echo "<p>"; 


$table_list=mysql_list_tables($db_name, $link); // 显 示 数 据 库 中 的 表 
while($row=mysql_fetch_row($table_list)) // 通 过 循环 遍历 返回 的 结果 集 


echo $row[0]; /显示 表 名 
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echo "<p>"; 


?> 
</body> 
</html> 


把 以 上 代码 保存 为 “14-5.php”。 在 PHP 执行 环境 中 运行 该 文件 ， 其 执行 结果 如 图 14.5 所 示 。 
上 例 中 使 用 了 mysql_list_tables0) 函 数 。 该 函数 的 作 
用 是 显示 库 中 所 有 的 表 。 就 像 前 面 讲 到 的 创建 数据 库 函 
数 mysql_create_ db(0) 一 样 ， 该 函数 也 已 经 被 废弃 ,所 以 不 
推荐 使 用 , 可 以 用 mysql_query() 发 送 一 条 SQL 语句 来 达 


当 在 库 中 创 娃 新 表 -Hi crosoft Internet kataa 
文件 四， RED FEV KRW IAV WA |V 


Kunio 
当前 test 上 的 所 有 数据 表 为 


testl 


到 和 函数 一 样 的 目的 。 显 示 所 有 数据 表 的 SQL 语句 是 : 昌 
“show tables”。 LE i AA A 
下 面 把 上 面 的 代码 做 一 下 调整 ， 把 其 中 的 14.5 在 库 中 创建 新 表 执行 结果 
$table_list=mysql_list_tables($db_name, $link); 
一 名 更 换 为 


$table list-mysg! guery("show tables", $link); 

然后 ， 重 新 执行 修改 过 的 PHP 文件 ， 可 以 看 到 执行 结果 是 完全 相同 的 (再 次 执行 时 要 把 创建 表 相 
关 儿 行 都 注释 掉 ， 或 者 再 换个 表 名 进行 创建 才 行 。 因 为 对 已 经 存在 的 表 进 行 创建 就 会 导致 错误 ) 。 

对 如 何 创建 表 ， 这 一 节 就 讲 到 这 里 。 这 一 节 不 仅 学 习 了 如 何 创建 表 ， 还 学 习 了 如 何 显示 库 中 所 有 
的 表 。14.3.5 节 就 讲解 如 何 对 表 内 数据 进行 操作 了 。 


14.3.5 如何 删 除 已 经 存在 的 库 和 表 


如 果 确 认 数据 库 或 者 里 面 的 表 已 经 不 再 需要 ， 就 可 以 将 库 或 者 表 删 除 。 如 何 删除 库 或 者 表 呢 ? 

删除 一 个 库 有 两 种 方法 ， 一 种 是 通过 PHP 中 的 MySQL 函数 mysql_drop_db(); 另 一 种 是 通过 
mysql_query() 函 数 发 送 SQL 语句 drop database database name. 

而 删除 一 个 表 只 有 一 种 方法 就 是 通过 mysql_query() 函 数 发 送 SQL 语句 drop table table name. 

下 面 分 别 来 介绍 如 何 删除 表 及 库 。 

先 来 看 如 何 删除 一 个 表 。 删 除 表 是 靠 mysql_query() 函 数 来 发 送 SQL 语句 drop table name 来 实现 ， 
其 中 的 table_name 指 代 将 要 被 删除 的 表 名 。 下 面 的 例子 演示 了 如 何 删除 test 库 中 的 表 testle BENA 
参看 以 下 代码 : 

<html> 

<head> 

<title> 在 库 中 删除 表 </title> 

</head> 

<body> 

<?php 

$db_host=localhost; /1IMySQL 服务 器 名 

$db_user=root; JIMYSOL 用 户 名 
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$db_pass=""; /MySQL 用 户 对 应 密码 

$db_name="test"; // 要 操作 的 数据 库 

/使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 返 回 相应 信息 
$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 


mysql_select_db($db_name,$link); // 选 择 相应 的 数据 库 ， 这 里 选择 test 库 
echo "当前 ".$db_name." 上 的 所 有 数据 表 为 :"; // 先 显示 表 删 除 之 后 再 显示 以 作 比较 
echo "<p>"; 


$table_list=mysql_list_tables($db_name,$link); // 显 示 数 据 库 中 的 表 
while($row=mysql_fetch_row($table list) // 通 过 循环 遍历 返回 的 结果 集 


{ 
echo $row[0]; /显示 表 名 
echo "<p>"; 
} 
$sql="drop table test1"; 1/ 删除 表 的 sql 语句 
if(mysql_query($sql,$link)) /| 执行 SQL 语句 
echo " 表 test1 已 经 被 删除 ! "; 
echo "<p>"; 
echo "当前 ".$db_name." 上 的 所 有 数据 表 为 :"; // 再 次 显示 删除 之 后 的 表 以 作 比较 
echo "<p>"; 


$table_listzmysql_list_tables($db_name, $link); /显示 数据 库 中 的 表 
while($row=mysql_fetch_row($table list) // 通 过 循环 遍历 返回 的 结果 集 
{ 

echo $row[0]; /显示 表 名 

echo "<p>"; 


} 


?> 

</body> 

</html> 

把 以 上 代码 保存 为 “14-6.php”， 然 后 在 PHP 执行 环境 下 运行 该 文件 在 执行 前 要 确认 已 经 建立 
了 test 库 及 testl 表 ) ， 其 执行 结果 将 会 如 图 14.6 所 示 。 

通过 图 14.6 可 以 看 到 ， 在 执行 删除 表 的 SQL 语 
名 之前， 对 库 进 行 遍历 ， 库 中 有 表 testle EATE 
删除 表 的 SQL 语句 后 ， 再 次 遍历 库 已 经 不 存在 testl 
表 了 。 说 明 该 表 已 经 被 成 功 删 除 。 

接 下 来 ， 学 习 如 何 删除 库 。 删 除 库 可 以 使 用 
mysql_drop_db() 函 数 ,或 者 用 mysql_query0 函 数 发 送 
SQL 请 求 drop database database_name， 都 能 够 实现 。 

这 里 使 用 后 一 种 方法 来 实现 。 下 面 的 代码 实现 了 把 服 maa 在 库 中 出 除 家 执行 结果 
务 器 上 的 名 为 data2 的 数据 库 进 行 删除 〈 在 执行 前 请 确保 MySQL 服务 器 中 有 data2 这 个 数据 库 ) 。 具 
体内 容 参看 以 下 代码 : 

<html> 

<head> 


<title> 删 除 服务 器 上 的 数据 库 </title> 


</head> 


DA PWRE -mi crosoft_ Internet Izplere aiolxi 
XPD RAV SFU KRW IAD WVW 


当前 test 上 的 所 有 数据 表 为 ， 
teatl 

Pitesti BEIMA 

当前 test 上 的 所 有 数据 表 为 ， 
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<body> 

<?php 

$db_host=localhost; /MySQL 服务 器 名 
$db_user=root; /MySQL 用 户 名 
$db_pass=""; /MySQL 用 户 对 应 密码 


/使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 返 回 相应 信息 
$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
$db list=mysql_list_dbs($link); // 先 显示 数据 库 以 与 删除 后 作 比 较 
while($db=mysql_fetch_object($db_ list) // 通 过 循环 遍历 返回 的 结果 集 

{ 


echo $db->Database; /显示 数据 库 名 ， 注 意 大 小 写 
echo "<p>"; 
} 
$sql="drop database data2"; 1/ 删除 数据 库 的 sql 语句 
if(mysql_query($sql,$link)) /| 执行 SQL 语句 
echo "数据 库 data2 已 经 被 删除 ! "; 
echo "<p>"; 
echo "当前 服务 器 上 的 所 有 数据 库 为 :"; // 再 次 显示 删除 后 的 数据 库 以 作 比 较 
echo "<p>"; 
$db_list=mysql_list_dbs($link); /显示 数据 库 
while($db=mysql_fetch_object($db_list)) // 通 过 循环 遍历 返回 的 结果 集 
{ 
echo $db->Database; /显示 数据 库 名 ， 注 意 大 小 写 
echo "<p>"; 
} 
?> 
</body> 
</html> 


保存 以 上 代码 为 “14-7.php”。 在 PHP 执行 环境 
中 执行 该 文件 ， 其 执行 结果 将 会 如 图 14.7 所 示 。 

通过 对 照 SQL 执行 前 后 对 服务 器 上 数据 库 的 遍 
历 可 以 看 到 ， 执 行 完 SQL 语句 后 ， 名 为 data2 的 数 
据 库 被 删除 了 。 说 明 以 上 程序 正常 运行 。 

如 何 删除 数据 库 及 表 ， 这 一 节 就 介绍 到 这 里 。 

在 使 用 对 数据 库 操作 时 有 一 点 需要 注意 ， 由 于 
当前 的 服务 提供 商 一 般 对 于 一 个 用 户 只 提供 一 个 数 
据 库 ， 所 以 普通 用 户 只 能 在 该 库 内 对 表 进 行 操作 ， 
无 权 创 建 或 者 删除 数据 库 。 所 以 在 执行 相关 操作 时 
是 不 会 有 结果 的 。 如 果 在 本 机 上 进行 调试 ， 就 没有 
这 个 限制 。 

14.4 节 将 为 读者 介绍 ， 如 何 对 表 进 行 操作 。 


BUREE 一 
XRD RED AFV 


data2 
databasel 
mysal 
test 
BARF dataz BiR 
当前 服务 器 上 的 所 有 数据 库 为 ， 
databasel 


mysql 


test zi 
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图 14.7 删除 服务 器 上 的 数据 库 执行 结果 
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14.4 对 MySQL 表 进 行 操作 


在 创建 了 库 ， 并 为 库 创 建 了 相应 的 表 后 ， 就 可 以 对 表 中 的 数据 进行 操作 了 。 其 实 对 表 的 操作 无 非 
就 是 插入 、 浏 览 、 修 改 、 删 除 这 几 项 。 而 这 几 项 操作 都 可 以 通过 mysql_query() 发 送 相 关 的 SQL 语句 来 
实现 。 这 一 节 就 来 为 读者 介绍 如 何 实现 对 数据 表 中 记录 的 插入 、 浏 览 、 修 改 及 删除 操作 。 认 真 学 过 本 
节 内 容 后 ， 读 者 能 对 如 何 操作 数据 表 ， 有 一 个 充分 的 认识 。 


14.4.1 HT INSERT INTO 语句 插入 记录 


一 个 表 在 创建 之 后 是 没有 任何 记录 的 ， 只 有 在 其 中 插入 记录 才能 发 挥 表 的 作用 。 要 对 表 中 插入 记 
K ILME mysql_query ORRE SQL 请 求 。SQL 语句 的 内 容 如 下 所 示 : 
insert into table_name(field01,field02…) values(values1,value2…) 


其 中 table name 是 表 的 名 称 ，field01 、field02 是 指 表 的 字段 名 称 ，values1、values2 是 指 想 要 插入 
的 记录 中 对 应 字段 的 值 。 

假如 有 名 为 testl 的 表 ， 它 的 结构 如 下 所 示 : 

id int(5) not null auto_increment primary key, 

name varchar(12) not null, 

mail varchar(30) not null, 


phone varchar(14) not null, 
address varchar(30) not null 


可 以 看 出 ， 该 表 有 5 列 〈 字 段 ) 。 分 别 是 ID (编号) NAME (名 称 ) MAIL (电子 信箱 》、 
PHONE (电话 ) 、ADDRESS 地址 ) 。 如 果 想 要 把 名 字 为 “ 张 三 ” 的 记录 插入 testl 表 中。 就 应 该 执 
行 这 样 的 操作 : 

insert into test1(name, mail,phone,address) values(" 张 三 ","zhangsan@homail.com","1234567"," 某 省 某 市 某 区 

某 街 ") 

为 什么 没有 给 ID 赋值 ? 因为 字段 ID 为 关键 字段 ， 并 且 具 有 自动 增加 1 的 属性 ， 所 以 不 用 为 其 单 
独 赋值 。 第 1 条 记录 的 ID 号 就 自动 为 1， 以 后 每 插入 一 条 ，ID 号 就 会 自动 向 后 增加 。 

下 面 ， 就 把 以 上 的 分 析 归 结 到 实际 的 例子 中 来 实际 执行 一 下 ， 以 检测 能 否 正 确 插 入 记录 在 执行 
前 ， 请 确保 test 库 中 有 testl 这 个 表 ， 如 果 没 有 ， 可 以 看 上 一 节 的 相关 内 容 ， 在 库 里 创建 一 个 ) 。 

<html> 

<head> 

<title> 在 表 中 插入 记录 </title> 

</head> 

<body> 

<?php 

$db_host=localhost; /MySQL 服务 器 名 

$db_user=root; /MySQL 用 户 名 
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$db_pass=""; 
$db_name="test"; 


/MySQL 用 户 对 应 密码 
// 要 操作 的 数据 库 


/使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 返 回 相应 信息 
$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 


mysql_select_ db($db_name,$link); 
$sgl-"select * from test1"; 
$result=mysql_query($sql,$link); 
echo "当前 表 中 的 记录 有 : "; 
echo "<p>"; 
while($row=mysql_fetch_array($result) 
{ 

echo $rowlid).", "; 

echo $row[name].", "; 

echo $row[mail].", "; 

echo $row[phone].", "; 

$rowladdress).", "; 

echo "<p>"; 


} 
/以 下 SQL 语句 为 插入 记录 操作 


// 选 择 相应 的 数据 库 ， 这 里 选择 test 库 
// 先 执行 SQL 语句 显示 所 有 记录 以 与 插入 后 相 比 较 
/使 用 mysql_query() 发 送 SQL 请 求 


IRA SQL 语句 执行 结果 把 值 赋 给 数组 


/显示 ID 

/显示 姓名 
/显示 邮箱 
/显示 电话 
/显示 地 址 


$sql="insert into test1(name,mail,phone,address) values(' 张 三 ,zhangsan@homail.com'"1234567',' 某 省 某 市 某 


区 某 街 ) 
if(mysql_query($sql)) 
echo "记录 已 经 成 功 插入 "; 
echo "<p>"; 
$sql="select * from test1"; 
$result=mysql_query($sql,$link); 
echo "当前 表 中 的 记录 有 : "; 
echo "<p>"; 
while($row=mysql_fetch_array($result)) 
{ 
echo $rowlid).”, "; 
echo $row[name].", "; 
echo $row[mail].","; 
echo $row[phone].", "; 
echo $rowladdress).", "; 
echo "<p>"; 
} 
?> 
</body> 
</html> 


把 以 上 代码 保存 为 “14-8.php”。 在 PHP 执行 环境 
下 运行 该 文件 ， 执 行 结果 将 会 如 图 14.8 所 示 。 
通过 图 14.8 可 以 看 到 ， 在 第 一 次 对 表 进 行 浏 览 操 


// 判 断 并 执行 SQL 语句 


// 先 执行 SQL 语句 显示 所 有 记录 以 与 插入 后 相 比 较 
// 使 用 mysql_query() 发 送 SQL 请 求 


// 再 次 遍历 结果 


/显示 ID 

/显示 姓名 
/显示 邮箱 
/显示 电话 
/显示 地 址 


与 丰 去 中 括 入 记录 -i crosnft Internet kaaa KA 
文件 如 SAO EFO HRW IAV EMW 


当前 表 中 的 记录 有 
记录 已 经 成 功 插入 
当前 表 中 的 记录 有 


作 时 ， 由 于 没有 任何 记录 ， 所 以 并 没有 任何 值 返回 。 当 
执行 完 SQL 语句 后 再 对 表 进 行 遍历 时 就 有 了 一 条 记 
录 , 并 且 显 示 出 了 记录 的 内 容 。 说 明 在 表 中 顺利 插入 了 
一 条 记录 。 


1， 张 三 ，zhangsan8ghomail. com，1234567， 某 省 某 
TRAH, 


me 


图 14.8 在 表 中 插入 记录 执行 结果 
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下 面 对 上 例 中 相关 的 一 些 函 数 作 用 做 简单 的 介绍 。 

mysql_fetch_array0: 返回 根据 从 结果 集 取得 的 行 生成 的 数组 。 

上 例 中 执行 了 select 查询 ， 对 表 的 内 容 进 行 浏览 ， 结 果 保 存 到 $result。 而 使 用 mysql_fetch_array() 
将 返回 根据 从 $result 取得 的 行 生成 一 个 数组 。 上 面 显 示 记 录 内 容 用 到 的 $row[id]、$row[anme] 等 数组 元 
素 ， 就 是 由 mysql_fetch_array() 函 数 获得 的 。 


14.4.2 执行 SELECT 查询 


显示 表 中 的 内 容 ， 或 者 对 表 中 特定 内 容 进行 搜索 时 都 需要 对 表 进 行 查询 。 所 以 对 表 的 查询 操作 也 
是 用 到 最 多 的 SQL 命令 之 一 。 对 表 中 记录 进行 浏览 要 使 用 mysql_query0) 函 数 发 送 SQL 请 求 。 查 询 是 
使 用 最 多 的 SQL 命令 。 查 询 数据 库 需 要 凭借 结构 、 索 引 和 字段 类 型 等 因素 。select 查询 的 基本 语法 如 
下 所 示 : 


SELECT [STRAIGHT_JOIN] [SQL_SMALL_RESULT] [SQL_BIG_RESULT] [HIGH_PRIORITY] 
[DISTINCT | DISTINCTROW | ALL] 

select_expression，.… 

[INTO {OUTFILE | DUMPFILE} file_name' export_options] 

[FROM table_references 

JIWHERE where definition) 

[GROUP BY col name, ...) 

[HAVING where definition) 

[ORDER BY funsigned integer | col name | formula} ][ASC | DESC] ，.…] 
[LIMIT ][offset，] rows] 

[PROCEDURE procedure_name] ] 


太 多 的 语法 ， 和 暂时 还 用 不 到 ， 以 后 在 高 级 查询 中 专门 为 读者 讲解 。 现 在 只 是 要 浏览 表 中 所 有 的 记 
。 只 需要 使 用 以 下 指令 : 
select * from tablename 


“*” 号 表示 所 有 内 容 ， 所 以 这 一 句 表示 查询 tablename 表 中 的 所 有 记录 。 这 在 前 一 小 节 对 数据 表 
插入 记录 时 已 经 见 到 过 。 
下 面 通过 一 个 实例 来 说 明 如 何 使 用 select 查询 获得 表 中 的 记录 。 


<html> 

<head> 

<title> 浏 览 表 中 记录 </title> 

</head> 

<body> 

<center> 

<?php 

$db_host=localhost; //MySQL 服务 器 名 
$db_user=root; JIMYSOL 用 户 名 
$db_pass=""; /MySQL 用 户 对 应 密码 
$db_name="test"; // 要 操作 的 数据 库 
/使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 返 回 相应 信息 


K 
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$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 


mysql_select_db($db_name, $link); // 选 择 相应 的 数据 库 ， 这 里 选择 test Æ 
$sql="select * from test1"; // 先 执行 SQL 语句 显示 所 有 记录 以 与 插入 后 相 比 较 
$result=mysql_query($sql,$link); /使 用 mysql_query() 发 送 SQL 请 求 
echo "当前 表 中 的 记录 有 :"; 
echo "<table border=1>"; // 使 用 表格 格式 化 数据 
echo "<tr><td>ID</td><td> 姓 名 </td><td> 邮 箱 </td><td> 电 话 </td><td> 地 址 </td></tr>"; 
while($row=mysql_fetch_array($result)) Ja SQL 语句 执行 结果 把 值 赋 给 数组 
t 

echo "<tr>"; 

echo "<td>". $row[id]."</td>"; /显示 ID 

echo "<td>".$row[name]." </td>"; /显示 姓名 

echo "<td>". $row[mail]." </td>"; /显示 邮箱 

echo "<td>".$row[phone]." </td>"; /显示 电话 

echo "<td>".$row[address]." </td>"; /显示 地 址 

echo "</tr>"; 
echo "</table>"; 当前 表 中 的 记录 有 ， 
eg WAA 电话 peat 
</center> 
</body> 1 ik [zhangsanðhomai1. com 1234567 ai 
</html> 
把 以 上 代码 保存 为 “14-9.php”。 在 PHP 执行 环境 ee 

中 执行 该 文件 ， 其 执行 结果 将 会 如 图 14.9 所 示 。 图 14.9 浏览 表 中 记录 执行 结果 


14.4.3 ”使 用 表单 扩展 添加 记录 功能 


虽然 insert into 是 执行 添加 记录 操作 的 核心 , 但 不 能 插入 一 条 记录 都 把 14-8.php 中 的 内 容 修改 一 遍 
执行 一 遍 。 所 以 应 该 采用 互动 的 形式 ， 用 户 输入 什么 数据 ， 就 插入 相应 的 记录 。 这 一 小 节 ， 把 14.4.1, 
14.4.2 节 的 内 容 结合 起 来 ， 再 利用 Web 表单 ， 来 实现 用 户 输入 记录 的 添加 ， 来 做 一 个 简易 的 通讯 录 。 


其 中 的 表 还 使 用 KIA testl 表 。 
显示 记录 的 页 面 ， 只 需要 把 14-9.php 作 简 单 修改 ， 把 标题 换 一 下 并 加 入 指向 添加 记录 前 台 
的 14-11.php 的 连接 ， 另 存 为 14-10.php， 以 备 后 用 。 


下 面 制作 添加 记录 的 前 台 , 主要 是 使 用 了 Web 表单 ， 并 把 form 的 action 属性 指向 目标 页 面 。 具体 


内 容 参 看 以 下 代码 : 


<html> 

<head> 

<title> 简 易 通 讯 录 添加 记录 前 台 </title> 
</head> 

<body> 

<script language="javascript"> 
function Juge(theForm) 


if (theForm.name.value == "") 
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{ 
alert(" 请 输入 姓名 ! "); 
theForm.name.focus(); 
retum (false); 

} 

if (theForm.phone.value =: 
alert(" 请 输入 电话 号 码 ! "); 
theForm.phone.focus(); 
retum (false); 

} 


if (theForm.address.value == "") 


alert(" 请 输入 地 址 !"); 
theForm.address.focus(); 
retum (false); 
i 
} 
</script> 
<center> 
<h1> 简 易 通讯 录 添 加 记录 前 台 </h1> 
<p> 
<a href="14-10.php"> 返 回首 页 </a> 
<table border=1> 
<form action="14-12.php" method="post" onsubmit="return Juge(this)"> 
<tr> 
<td> 输 入 姓名 : </td> 
<td><input name="name" type= "text"></td> 
</tr> 
<tr> 
<td> 输 入 邮箱 ;</td> 
<td><input name="mail" type="text"></td> 
</tr> 
<tr> 
<td> 输 入 电话 : </td> 
<td><input name="phone" type="text"></td> 
</tr> 
<tr> 
<td> 输 入 地 址 : </td> 
<td><input name="address" type="text"></td> 
</tr> 
<tr> 
<td colspan="2"><center><input type=submit value=" 确 认 提交 "> 
<input type=reset value=" 重 新 选择 "></center></td> 
</tr> 
</form> 
</table> 
</center> 
</body> 
</html> 
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把 以 上 代码 保存 为 “14-11.php”。 备 用 。 


名 ， 把 记录 插入 表 中 。 下 面 的 例子 ， 还 说 明了 一 


册 表 ， 这 是 实现 与 用 户 互动 的 关键 技术 。 


<? 


/下 面 内 容 为 获取 表单 输入 ， 并 去 掉 HTML 格式 。 


最 后 制作 对 输入 记录 的 后 台 处 理 页 面 。 添 加 记录 的 核心 还 是 使 用 INSERT INTO 这 样 一 条 SQL 语 
个 问题 ， 如 何 获取 表单 输入 的 数据 ， 并 把 记录 存 入 注 


由 于 表单 采用 post 方式 传递 数据 ， 所 以 用 post 来 获取 输入 */ 


$name=htmlspecialchars($_POST[name]); 
$mail=htmlspecialchars($_POST[mail]); 
$phone=htmlspecialchars($_POST[phone']); 


$address=htmlspecialchars($_POST['address]); 


$db_host=localhost; 
$db_user=root; 
$db_pass=""; 
$db_name="test"; 
S$table_name="test1"; 


// 获 取 姓 名 

/获取 邮箱 

/获取 电话 

/获取 地 址 

/MySQL 服务 器 名 
/MySQL 用 户 名 
/MySQL 用 户 对 应 密码 
// 要 操作 的 数据 库 
IRB 


$myconn=mysql_connect("$db_host","$db_user","$db_pass"); /连接 服务 器 


mysql_select_ db("$db_name",$myconn); 


/选择 操作 库 


$strSql="insert into $table_name(name,mail,phone,address) values ($name','$mail','$phone','$address')"; 


// 对 表 进 行 插入 操作 


mysql_query($strSql,$myconn) or die(" 插 入 时 出 错 ".mysql_error());// 发 送 SQL 请 求 


?> 

<html> 

<head> 

<title> 简 易 通讯 录 添加 记录 处 理 </title> 
</head> 


<meta http-equiv="refresh" content="2; ur=14-10.php"> 


<body> 
已 经 成 功 添加 记录 ， 两 秒 后 返回 。 
</body> 
</html> 


把 以 上 代码 保存 为 “14-12.php” 


。 至 此 ， 整 个 简易 通讯 录 程序 就 算是 制作 完毕 了 。 到 底 能 否 


手动 输入 记录 信息 ， 并 把 记录 插入 到 表 中 呢 ? 下 面 就 来 运行 一 下 整个 程序 ， 看 执行 结果 。 
首先 运行 14-10.php， 其 执行 结果 将 会 如 图 14.10 所 示 。 
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图 14.10 简易 通讯 录 显示 数据 页 执行 结果 


从 图 14.10 的 执行 结果 可 见 


， 显示 出 了 原 有 的 数据 (这 数据 是 在 前 面 讲 的 内 容 中 添加 的 )。 接 下 来 ， 


256" PHP 网 络 编程 从 入 门 到 精通 


单 击 添加 记录 连接 ， 相 当 于 执行 14-11.php。 单 击 连接 后 的 结果 如 图 14.11 所 示 。 
由 于 表 中 记录 只 有 5 项 ,而 ID 一 项 还 是 主键 并 且 具 有 自动 增加 的 属性 。 所 以 不 必 为 其 添加 值 。 只 
需要 输入 图 14.12 所 示 的 4 项 内 容 即 可 。 按 照 提 示 输 入 相应 的 信息 。 这 里 输入 以 下 简单 信息 : 李 四 、 
lisi@mircosoft.com、2345678、 北 京 市 海淀 区 (读者 也 可 以 根据 自己 需要 输入 合适 的 信息 ) 。 输 入 完 后 
单 击 “ 确 认 提 交 ” 按 钮 ， 将 转 到 14-12.php。 

而 14-12.php 只 对 数据 进行 了 处 理 ， 马 上 又 自动 跳 转 到 了 14-10.php， 如 图 14.12 所 示 。 
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图 14.11 简易 通讯 录 添 加 记录 前 台 执行 结果 14.12 插入 后 的 数据 显示 页 执行 结果 

通过 图 14.12 TIL, 显示 的 记录 中 在 原 有 的 张 三 后 ,又 显示 了 刚刚 插入 的 李 四 的 记录 , 说 明 记 录 已 

经 被 插 到 数据 库 之 中 。 该 简易 通讯 录 程 序 测试 通过 。 


当前 表 中 的 记录 有 : 
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1444 执行 UPDATE 语句 更 新 记录 


记录 在 入 库 后 ， 并 不 是 一 成 不 变 的 , 有 时 可 能 需要 对 某 些 内 容 作 相应 的 调整 , 这 时 就 要 用 到 update 
语句 对 记录 进行 更 新 (修改 ) 了 。update 语句 的 使 用 格式 如 下 : 
update table name set field01="value1",field02="value02" where where definition 


其 中 的 table name 为 欲 操作 的 表 名 。field01、field02 为 字段 名 ， 而 后 面 的 valuel, value? 为 想 要 
更 改 为 的 内 容 。 后 面 的 where_definition 为 更 改 源 记录 的 条 件 。 比 如 想 把 testl 表 中 张 三 的 记录 改 为 王 五 
的 ， 可 以 执行 以 下 操作 。 

update test1 set name=" 王 五 "mail="wangwu@tom.com",phone="3456789",address=" 上 海 市 高 新 开发 区 " 

where name=" 张 三 "; 

后 面 的 where name=" 张 三 "如 果 改 成 id=1 会 更 合适 。 因 为 字段 ID 是 主键 ， 并 且 具 有 唯一 性 ， 所 以 
不 可 能 出 现 重复 。 而 name 则 不 一 样 , 如 果 有 重 名 的 “ 张 三 ” 则 执行 相应 的 操作 会 把 所 有 的 都 进行 更 新 。 
下 面 就 把 这 段 代 码 加 入 到 实际 的 PHP 文件 中 ， 看 如 何 使 用 UPDATE 语句 来 更 改 已 经 存在 的 记录 。 具 
体内 容 参看 以 下 代码 : 

<html> 

<head> 

<title> 更 改 表 中 记录 </title> 


</head> 
<body> 
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<center> 

<?php 

$db host-localhost; /MySQL 服务 器 名 
$db_user=root; /MySQL 用 户 名 
$db_pass=""; /MySQL 用 户 对 应 密码 
$db_name="test"; // 要 操作 的 数据 库 


// 使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 返 回 相 应 信息 
$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 


mysql_select_db($db_name,$link); 
function show con() 


// 选 择 相应 的 数据 库 ， 这 里 选择 test 库 
// 把 显示 记录 功能 做 成 函数 以 便 多 次 调用 


{ 
$link=mysql_connect(localhost,root,""); 
mysql_select_db(test); 
$sql="select * from test1"; // 先 执行 SQL 语句 显示 所 有 记录 以 与 更 改 后 相 比较 
$result=mysql_query($sql,$link); /使 用 mysql_query() 发 送 SQL 请 求 
echo "<table border=1>"; // 使 用 表格 格式 化 数据 
echo "<tr><td>ID</td><td> 姓 名 </td><td> 邮 箱 </td><td> 电 话 </td><td> 地 址 </td></tr>"; 
while($row=mysql_fetch_array($result)) // 人 遍历 SQL 语句 执行 结果 把 值 赋 给 数组 
{ 
echo "<tr>"; 
echo "<td>".$row[lid]."</td>"; /显示 ID 
echo "<td>".$row[name]." </td>"; /显示 姓名 
echo "<td>".$row[mail]." </td>"; /显示 邮箱 
echo "<td>".$row[phone]." </td>"; NRF EE 
echo "<td>".$row[address]." </td>"，// 显 示 地 址 
echo "</tr>"; 
echo "</table>"; 
} 
echo "更 新 前 的 记录 为 :"; 
show_con(); // 调 用 函数 ， 显 示 表 中 所 有 记录 
$sql="update test1 set name=' 王 五 ,mail=wangwu@tom.com',phone='3456789',address=' 上 海 市 高 新 开发 区 ' 
where id=1"; // 创 建 更 新 记录 SQL 语句 
mysql_query($sql, $link); // 发 送 SQL 请 求 
echo "更 新 后 的 记录 为 :"; 
show_con(); // 再 次 调用 函数 ， 显 示 表 中 记录 以 做 比较 
?> 
</center> 
Sbon zipi 
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司 


把 以 上 代码 保存 为 “14-13.php”， 在 PHP 
执行 环境 下 运行 该 文件 ， 执 行 结果 如 图 14.13 
所 示 。 

从 图 14.13 执行 结果 可 以 看 到 在 执行 更 新 
数据 操作 之 前 ， 调 用 显示 记录 函数 返回 的 第 1 
条 记录 为 张 三 。 而 执行 完 更 新 操作 后 ， 再 次 调 
用 显示 记录 函数 ， 返 回 的 第 1 条 记录 已 经 成 了 


当前 表 中 的 记录 有 : 
DRE ip 电话 


2 摩 四 1isi@nircosoft. com 
当前 表 中 的 记录 有 ， 
Ditz BE [mis | 地 址 
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图 14.13 更 改 表 中 记录 执行 结果 
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王 五 了 。 说 明 顺 利 地 把 表 中 记录 号 为 1 的 记录 进行 了 更 改 。 


14.4.5 ”使 用 表单 扩展 更 改 记录 功能 


就 像 插 入 记录 操作 一 样 ， 不 可 能 每 更 改 一 条 记录 就 修改 一 次 14-13.php 中 的 内 容 ， 并 执行 一 次 该 
PHP 文件 。 如 果 能 与 Web 表单 结合 起 来 ， 实 现 用 户 输入 什么 内 容 ， 就 更 改 什么 内 容 ， 那 样 就 会 方便 很 


多 。 下 面 ， 就 来 介绍 ， 如 何 使 用 


Web 表单 与 更 改 数据 记录 的 操作 结合 起 来 。 这 一 节 ， 要 把 14.4.2 节 所 


制作 的 显示 记录 文件 作 简单 的 修改 。 具 体 代码 如 下 : 


<html> 

<head> 
<title> 浏 览 表 中 记录 </title> 
</head> 

<body> 

<center> 

<?php 
$db_host=localhost; 
$db_user=root; 
$db_pass=""; 
$db_name="test"; 


/MySQL 服务 器 名 
/MySQL 用 户 名 
/MySQL 用 户 对 应 密码 
// 要 操作 的 数据 库 


// 使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 返 回 相应 信息 
$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
mysql_select_db($db_name,$link); // 选 择 相应 的 数据 库 ， 这 里 选择 test 库 


$sql="select * from test1"; 


// 先 执行 SQL 语句 显示 所 有 记录 以 与 插入 后 相 比 较 


$result=mysql_query($sql,$link); /使 用 mysql_query() 发 送 SQL 请 求 


echo "当前 表 中 的 记录 有 :"; 
echo "<table border=1>"; 


// 使 用 表格 格式 化 数据 


echo "<tr><td>ID</td><td> 姓 名 </td><td> 邮 箱 </td><td> 电 话 </td><td> 地 址 </td><td>&nbsp;</td></tr>"; 


while($row=mysql_fetch_array($result) INRA SQL 语句 执行 结果 把 值 赋 给 数组 
echo "<tr>"; 
echo "<td>". $row[id]."</td>"; /显示 1D 
echo "<td>".$row[name]." </td>"; /显示 姓名 
echo "<td>".$row[mail]." </td>"; /显示 邮箱 
echo "<td>".$row[phone]." </td>"; /显示 电话 
echo "<td>".$row[address]." </td>"; /显示 地 址 
echo "<td><a href="14-15.php?id=".$row[id]."> 修 改 </a></td>"; 
echo "</tr>"; 
} 
echo "</table>"; 
?> 
</center> 
</body> 
</html> 


可 以 看 出 , 与 14-10.php 不 同 的 是 ， 为 显示 的 表格 增加 了 一 列 ， 列 中 显示 指向 修改 记录 前 台 页 面 的 


连接 。 把 以 上 代码 保存 为 “14-14.php”， 以 备 后 
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下 面 制作 修改 记录 的 前 台 页 面 。 该 页 面 与 14-11.php 即 插入 记录 的 前 台 基本 相似 ,不 同 的 是 由 于 是 
修改 已 经 存在 的 记录 ， 所 以 要 能 显示 原 有 的 记录 内 容 。 具 体 修改 内 容 参看 以 下 代码 : 


<html> 

<head> 

<title> 简 易 通 讯 录 修改 记录 前 台 </title> 
</head> 

<body> 


<script language="javascript"> 
function Juge(theForm) 


{ 
if (theForm.name.value == "") 
alert(" 请 输入 姓名 ! "); 
theForm.name.focus(); 
retum (false); 
} 
if (theForm.phone.value == "") 
alert(" 请 输入 电话 号 码 ! "); 
theForm.phone.focus(); 
retum (false); 
} 
if (theForm.address.value == "") 
alert(" 请 输入 地 址 !"); 
theForm.address.focus(); 
retum (false); 
} 
} 
</script> 
<center> 
<h1> 简 易 通 讯 录 修 改 记录 前 台 </h1> 
<p> 


<a href="14-14.php"> 返 回首 页 </a> 
<table border=1> 
<form action="14-16.php" method="post" onsubmit="return Juge(this)"> 


<? 
$link=mysql_connect(localhost,root,""); 
mysql_select_db(test, $link); /选择 相应 的 数据 库 ， 这 里 选择 test Æ 


$sql="select * from test1 where id=$_GET[id]"; // 只 显示 请 求 ID 号 的 内 容 
$result=mysql_query($sql); 


$row=mysql_fetch_array($result); // 把 结果 赋值 给 数组 
?> 

<input type="hidden" name="id" value="<?echo $row[id]?>"> 

<tr> 


<td> 输 入 姓名 : </td> 
<td><input name="name" type="text" value="<?echo $row[name]?>"></td> 
</tr> 
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<tr> 

<td> 输 入 邮箱 : </td> 

<td><input name="mail" type="text" value="<?echo $row[mail]?>"></td> 
</tr> 

<tr> 

<td> 输 入 电话 : </td> 

<td><input name="phone" type="text" value="<?echo $row[phone]?>"></td> 
</tr> 

<tr> 

<td> 输 入 地 址 : </td> 

<td><input name="address" type="text" value="<?echo $row[address]?>"></td> 
</tr> 

<tr> 

<td colspan="2"><center><input type=submit value=" 确 认 提 交 "> 

<input type=reset value=" 重 新 选择 "></center></td> 

</tr> 

</form> 

</table> 

</center> 

</body> 

</html> 


可 以 看 出 ， 上 面 代码 与 14-11.php 的 不 同 , 就 是 多 了 一 项 ， 从 表 中 查找 出 想 要 修改 的 记录 的 原始 内 
容 。 并 把 相应 的 值 赋 值 给 相应 的 表单 元 素 。 同 时 ， 该 表单 中 多 了 一 个 隐藏 的 表单 元 素 ID， 它 指向 记录 
的 ID， 作 为 提交 表单 并 且 修 改 记录 的 条 件 。 

把 以 上 代码 另存 为 “14-15.php”， 以 备 后 用 。 

接 下 来 制作 修改 记录 的 后 台 操 作 页 面 。 具 体 代码 如 下 所 示 : 

<? 


/下面 内 容 为 获取 表单 输入 ， 并 去 掉 HTML 格式 。 
由 于 表单 采用 post 方式 传递 数据 ， 所 以 用 post 来 获取 输入 */ 


$name=htmlspecialchars($_POST[name]); /获取 姓名 
$mail=htmlspecialchars($_POST[mail]); /获取 邮箱 
$phone=htmlspecialchars($_POST[phone]); /获取 电话 
$address=htmlspecialchars($_POST['address]); /获取 地 址 

id=$_POST[id]; /获取 ID 

$db_host=localhost; /MySQL 服务 器 名 
$db_user=root; /MySQL 用 户 名 
$db_pass=""; /MySQL 用 户 对 应 密码 

$db name-"test"; // 要 操作 的 数据 库 
S$table_name="test1"; IRZ 
$myconn=mysql_connect("$db_host","$db_user","$db_pass"); // 连 接 服务 器 
mysql_select_db("$db_name",$myconn); /| 选择 操作 库 

$strSql="update $table name set name-'$name',mail-'$mail',phone-'$phone',address-'$address' where 
id=$id"; // 对 表 进 行 修改 操作 
mysql_query($strSql,$myconn) or die(" 插 入 时 出 错 ".mysql_error());// 发 送 SQL 请 求 
?> 

<html> 


<head> 
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<html> 

<head> 

<title> 简 易 通讯 录 修 改 记录 处 理 </title> 

</head> 

<meta http-equiv="refresh" content="2; url=14-14.php"> 
<body> 

已 经 成 功 修改 记录 ， 两 秒 后 返回 。 

</body> 

</html> 


可 以 看 出 以 上 代码 与 14-12.php 也 基本 类 似 ， 除 了 $SQL 语句 内 容 有 所 不 同 ， 其 他 地 方 都 相同 。 把 
以 上 代码 保存 为 “14-16.php”， 以 备 后 用 。 

这 3 个 文件 创建 完毕 , 开始 测试 更 改 功能 是 否 起 作用 。 第 1 步 先 在 PHP 执行 环境 中 运行 14-14.php。 
其 结果 如 图 14.14 所 示 。 

从 图 14.14 可 以 看 出 与 图 14.10 的 不 同 之 处 就 在 于 表格 多 出 一 列 修改 的 连接 。 单 击 该 连接 ， 进 入 相 
应 的 修改 页 面 。 这 里 单 击 第 1 条 记录 后 面 的 连接 ， 就 连接 到 14-15.php， 其 执行 结果 如 图 14.15 所 示 。 
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图 14.14 浏览 表 中 记录 带 修改 连接 执行 结果 图 14.15 简易 通讯 录 修改 记录 前 台 执行 结果 


从 图 14.15 可 以 看 出 , 连接 到 此 页 , 显示 出 了 原来 存在 的 记录 的 内 容 。 下 面 对 该 记录 进行 适当 修改 。 
为 了 便于 对 照 , 只 把 其 中 的 电话 由 3456789 改 为 1234567。 把 上 海 市 高 新 开发 区 , 修改 为 上 海 市 南京 路 
(读者 也 可 以 根据 自己 需要 进行 相应 的 修改 ) 。 其 他 内 容 保持 不 变 。 输 入 相应 内 容 后 ， 单 击 “ 确 认 提 
交 ” 按 钮 。 将 转 到 14-16.php 对 数据 进行 处 理 。 执 行 结果 如 图 14.16 所 示 。 
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图 14.16 修改 记录 后 台 处 理 执行 结果 
由 于 14-16.php 使 用 了 页 面 自动 跳 转 ， 所 以 在 执行 完 修改 记录 操作 后 ， 直 接 跳 转 到 了 14-14.php。 
不 过 ， 比 较 图 14.14 与 图 14.16 可 以 发 现 ，ID 号 为 1 的 记录 中 的 电话 号 码 和 地 址 都 已 经 发 生 了 改变 。 
原来 的 内 容 ， 变 成 了 在 图 14.15 中 输入 的 内 容 。 说 明 对 数据 的 重新 记录 操作 顺利 执行 。 
这 一 节 用 Web 表单 扩展 修改 表 中 记录 的 功能 就 介绍 到 这 里 。 如 果 把 这 一 小 节 所 介绍 的 内 容 与 14.4.3 
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小 节 所 介绍 的 功能 结合 起 来 ， 就 是 一 个 功能 完善 〈 添 加 记录 、 修 改 记录 ) 的 简易 通讯 录 程 序 了 。 
14.4.6 执行 DELETE 语句 删除 记录 


数据 表 中 的 内 容 如 果 不 再 需要 ， 为 了 节省 空间 ,把 多 余 的 不 再 需要 的 记录 从 表 中 删除 是 有 必要 的 。 
这 一 节 为 读者 介绍 ， 如 何 删除 表 中 的 记录 。 

要 想 删 除 表 中 的 不 再 需要 的 记录 , 可 以 使 用 mysql_query() 函 数 发 送 一 条 delete 的 SQL 语句 。delete 
的 使 用 语法 如 下 所 示 : 

delete from table name where t field01-"value1" 

其 中 的 table_name 为 欲 删除 的 记录 所 在 的 表 名 。 后 面 的 where 子 句 表示 执行 操作 的 条 件 。field01 
指 字段 名 ，valuel 指 对 应 于 字段 field01 的 值 。 如 想 把 testl 表 中 王 五 的 记录 删除 ， 可 以 执行 以 下 操作 。 


delete from test1 where t naame=" 王 五 " 


正如 14.4.4 小 节 提 到 的 那样 ， 字 段 ID 是 表 testl 的 主键 ， 并 且 具 有 唯一 性 。 所 以 如 果 把 上 面 代码 
中 的 name=" 王 五 "更 改 为 id=1 会 更 好 的 执行 操作 。 下 面 就 把 这 段 代 码 加 入 到 实际 的 PHP 文件 中 ， 看 如 
何 使 用 DELETE 语句 来 删除 已 经 存在 且 不 再 需要 的 记录 。 有 具体 内 容 请 参看 如 下 代码 : 


<html> 

<head> 

<title> 删 除 表 中 记录 </title> 

</head> 

<body> 

<center> 

<?php 

/使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 返 回 相 应 信息 
$link=mysql_connect(localhost,root,")or die(" 不 能 连接 到 服务 器 ".mysql_error()); 


mysql_select_db(test, $link); // 选 择 相应 的 数据 库 ， 这 里 选择 test 库 
function show_con() // 把 显示 记录 功能 做 成 函数 以 便 多 次 调用 
{ 


$link=mysql_connect(localhost,root,""); 
mysql_select_db(test); 


$sql="select * from test1"; // 先 执行 SQL 语句 显示 所 有 记录 以 与 更 改 后 相 比 较 
$result=mysql_query($sql,$link); /使 用 mysql_query() 发 送 SQL 请 求 
echo "<table border=1>"; /使 用 表格 格式 化 数据 


echo "<tr><td>ID</td><td> 姓 名 </td><td> 邮 箱 </td><td> 电 话 </td><td> 地 址 </td></tr>"; 
while($row=mysql_fetch_array($result)) // 人 遍历 SQL 语句 执行 结果 把 值 赋 给 数组 
{ 

echo "<tr>"; 

echo "<td>".$rowlid]."</td>"; /显示 ID 

echo "<td>".$row[name]." </td>"; NEREZ 

echo "<td>".$row[mail]." </td>"; /显示 邮箱 

echo "<td>".$row[phone]." </td>"; BFE 

echo "<td>".$row[address]." </td>"; // 显 示 地 址 

echo "</tr>"; 
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echo "</table>"; 


} 

echo "删除 前 的 记录 为 :"; 

show_con(); // 调 用 函数 ， 显 示 表 中 所 有 记录 
$sql="delete from test1 where id=1"; // 创 建 更 新 记录 SQL 语句 
mysql_query($sql, $link); // 发 送 SQL 请 求 

echo "<p>"; 

echo "删除 后 的 记录 为 :"; 

show_con(); /再 次 调用 函数 ， 显 示 表 中 记录 以 做 比较 


</center> 
</body> 
</html> 


把 以 上 代码 保存 为 “14-17.php”。 然 后 在 
PHP 执行 环境 下 运行 该 文件 ， 执 行 结 果 将 会 如 
图 14.17 所 示 。 删除 后 的 记录 为 

通过 图 14.17 可 以 看 出 ,在 执行 删除 操作 前 ， F $a i mza MARREK 
遍历 表 的 结果 , 表 中 有 两 条 记录 。 而 在 执行 了 删 
除 操作 后 ，ID 号 为 1 的 记录 ， 已 经 从 表 中 被 删 
除了 。 说 明 删除 操作 顺利 执行 。 图 14.17 删除 表 中 记录 执行 结果 


Eg mua 


C 


14.4.7 执行 ALTER TABLE 语句 改变 表 的 结构 


数据 表 在 建立 后 ， 并 不 是 一 成 不 变 的 ， 有 时 需要 增删 表 的 某 些 字段 。 如 通讯 录 表 在 建立 后 ， 只 有 
姓名 、 邮 箱 、 电 话 、 地 址 几 项 可 能 还 不 能 满足 需要 ， 还 要 再 加 上 手机 号 一 项 新 的 内 容 。 或 者 其 中 邮箱 
一 项 不 再 需要 可 予以 删除 。 这 时 就 要 使 用 到 ALTER TABLE 语句 来 改变 表 的 结构 。 该 语句 的 使 用 格式 
如 下 所 示 : 

alter table table name add column field_name1 date,add column field name2 time*…; 

其 中 的 table name 是 想 要 改变 结构 的 表 名 ，field_namel 与 field_name2 为 想 要 添加 的 字段 名 ， 跟 
在 它们 后 面 的 date 和 time 表示 该 字段 的 类 型 。 如 要 给 表 testl 增加 手机 和 生日 列 ， 就 可 以 使 用 以 下 
格式 。 

alter table test1 add column mob phone varchar(11),add column birthday varchar(8); 

可 见 要 增加 表 的 字段 ， 后 面 要 加 上 add column 关键 字 。 下 面 介 绍 如 何 删除 某 个 字段 。 

删除 字段 也 是 使 用 alter table 语句 ， 只 不 过 跟 上 drop column 关键 字 。 有 具体 格式 如 下 所 示 : 

alter table table name drop column field name1,drop column field_name2…; 

如 要 删除 表 testl 中 的 邮箱 一 项 ， 就 可 以 使 用 以 下 格式 。 

alter table test1 drop mail; 

通过 对 上 面 两 种 情况 的 介绍 后 ， 读 者 可 以 发 现 ， 无 论 是 为 表 添 加 字段 ， 还 是 删除 表 中 已 有 字段 ， 
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均 是 使 用 alter table 语句 。 不同 的 是 增加 字段 后 面 跟 的 是 add column 关键 字 , 而 删除 字段 使 用 的 是 drop 
column 关键 字 。 
在 实际 执行 这 些 操作 之 前 ， 有 必要 先 介绍 一 个 与 数据 表 列 有 关 的 函数 mysql_list_fields0。 该 函数 
的 作用 是 返回 指定 表 的 所 有 字段 。 所 以 在 变更 表 的 结构 之 前 先 调用 该 函数 ， 在 执行 完 相 关 的 操作 后 ， 
再 次 调用 该 函数 ， 就 可 以 真实 的 对 比 执行 前 后 的 差别 。 该 函数 的 使 用 格式 如 下 所 示 : 
mysql_list_fields(string database name,string table_name[,resource link identifier)) 


但 是 由 于 该 函数 已 经 过 时 ， 所 以 要 使 用 mysql_query0) 函 数 发 送 SQL 请 求 “show columns from 
table_name” 来 蔡 换 该 函数 。 

下 面 就 实际 地 来 使 用 alter table 语句 ， 看 一 看 是 如 何 对 表 的 结构 进行 改变 的 。 同 时 也 来 看 一 看 如 何 
使 用 相应 的 SQL 语句 “show columns from table_name” 来 返回 表 的 所 有 字段 。 具 体内 容 请 参看 以 下 
代码 : 


<html> 

<head> 

<title> 改 变 表 的 结构 </title> 

</head> 

<body> 

<center> 

<?php 

/使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 返回 相应 信息 
$link=mysql_connect(localhost,root,"")or die(" 不 能 连接 到 服务 器 ".mysql_error()); 


mysql_select_db(test,$link); // 选 择 相应 的 数据 库 ， 这 里 选择 test 库 
function show field() // 把 显示 字段 功能 做 成 函数 以 便 多 次 调用 
{ 


$link=mysql_connect(localhost,root")or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
mysql_select_db(test,$link); IRIRA RGR, AEA test Æ 
$result=mysql_query("show columns from test1"); 

echo "test1 表 中 现 有 的 字段 内 容 为 : "; 

while($row=mysql_fetch_array($result)) // 人 遍历 表 中 的 所 有 字段 


{ 
echo $row["Field"]; 
echo "<p>"; 
} 
} 
echo "删除 前 : "; 
echo "<p>"; 
show field(); /显示 表 的 所 有 字段 
echo "<p>"; 
echo "MRE: "; 
echo "<p>"; 
$sql="alter table test1 add column mob phone varchar(11),add column birthday varchar(8)"; 
mysqlL_query($sql); /执行 添加 字段 的 SQL 语句 
$sql="altertable test1 drop mail"; 
mysqlL_query($sql); // 执 行 删除 字段 的 SQL 语句 
show field(); // 再 次 显示 表 的 所 有 字段 


?> 
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</center> 

</body> 

</html> 

把 以 上 代码 保存 为 “14-18.php”。 然 后 在 PHP 执行 环境 中 运行 该 文件 ， 其 执行 结果 如 图 14.18 
所 示 。 

从 图 14.18 中 可 以 看 出 ， 在 执行 改变 表 结 构 
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前 表 中 有 5 个 字段 ,分 别 是 id、name、mail、phone、 ka 

address。 可 是 在 执行 改变 表 的 结构 的 操作 后 ， 字 WA ka 

段 变 为 了 6 个 ,分 别 是 : id, name, phone, address, wa 
mob_phone、birthday。 原 来 的 mail 字段 被 删除 EIA 

了 , 而 又 新 添加 了 mob phone 和 birthday 两 个 字 id. name, phone, address, nob_ phone. birthday, 

段 。 通过 执行 结果 可 以 明显 发 现 , 改变 表 的 结构 。 ”am uu 
的 语句 是 如 何 发 生 作用 。 图 14.18 改变 表 的 结构 执行 结果 


随 着 对 改变 表 的 结构 的 学 习 ， 这 一 节 对 
MySQL 表 进 行 操作 也 基本 告 一 段落 。 简 单 回顾 一 下 ， 这 一 节 学 习 了 如 何 插入 记录 、 如 何 浏览 记录 、 如 
何 更 新 记录 ， 如 何 改变 表 的 结构 等 几 部 分 的 内 容 。 这 些 内 容 是 使 用 MySQL 数据 库 时 最 常用 到 的 。 只 
有 熟练 掌握 了 这 些 基 本 内 容 , 才能 在 这 些 基础 上 开发 出 基于 MySQL 数据 库 的 高 效率 的 Web 应 用 程序 。 


14.5 对 MySQL 表 的 高 级 查询 


14.4 节 介 绍 的 对 数据 表 的 浏览 ， 只 是 简单 的 显示 所 有 记录 ， 并 没有 附加 任何 的 条 件 ， 也 没有 对 输 
出 结果 的 约束 。 这 一 节 介绍 常用 在 SELECT、DELETE 和 UPDATE 操作 中 所 附加 的 子 句 。 通 过 这 些 子 
句 一 方面 能 对 执行 的 操作 附加 条 件 ， 而 一 方面 也 对 显示 的 结果 有 所 限制 。 这 样 就 可 以 实现 更 多 的 功 
能 了 。 


14.5.1 使 用 WHERE FA) 


不 管 是 进行 查询 、 删 除 或 者 修改 操作 时 通常 都 是 需要 附加 条 件 的 。 而 where 子 句 就 为 执行 的 
SELECT, DELETE 和 UPDATE 操作 附加 条 件 。 如 想 要 浏览 表 testl 中 ID 号 小 于 10 的 用 户 记录 就 可 以 
这 样 使 用 WHERE 子 句 : 

select * from test1 where id<10 

这 样 ， 只 有 满足 条 件 (ID 小 于 10 的 记录 ) 才 会 被 浏览 到 。 

同时 where 也 可 以 用 来 作为 数据 搜索 的 条 件 。 如 果 记 录 特 别 多 ， 从 中 所 有 的 记录 中 找 出 一 条 记录 
就 非常 麻烦 ， 这 时 使 用 where 子 句 就 简单 的 多 了 。 比 如 要 查看 某 一 个 人 《如 : 张 三 ) 的 详细 信息 就 可 
以 这 样 使 用 WHERE 子 句 : 


select * from test1 where name=' 张 三 ' 
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这 样 就 可 以 显示 出 所 有 名 字 为 张 三 的 记录 可 能 不 只 一 个 人 ， 因 为 可 能 有 重 名 的 情况 )。 

同时 ，WHERE 子 句 也 可 以 用 到 UPDATE 更 新 操作 及 DELETE 删除 操作 中 。 

如 在 一 个 论坛 中 有 很 多 用 户 ， 其 中 有 普通 会 员 、 版 主 、 超 级 版 主 、 管 理 员 等 。 到 了 节日 时 ， 要 给 
所 有 的 会 员 加 分 (实际 上 是 改变 积分 的 值 》》， 就 可 以 根据 用 户 不 同 的 身份 ， 给 予 不 同 的 处 理 。 如 下 面 
的 几 句 。 

下 面 这 一 句 给 普通 用 户 增 加 10 分 : 

update table name set score=score+10 where shenfen="normal"; 

下 面 这 一 句 给 普通 版 主 增加 100 分 : 


update table name set score=score+100 where shenfen="banzhu"; 


下 面 这 一 句 给 超级 版 主 增加 200 分 : 

update table name set score=score+200 where shenfen="super ; 

经 过 以 上 3 句 SQL 语句 的 操作 ， 不 同 的 用 户 就 会 被 给 予 不 同 的 积分 奖励 。 

为 什么 非 要 用 3 句 ? 用 一 名 加 上 3 个 条 件 不 是 更 好 ? 注意 这 一 点 是 不 被 允许 的 ， 因 为 MySQL 并 
不 支持 多 重 WHERE。 所 以 以 上 3 步 操作 不 能 放 到 一 条 语句 中 。 

虽然 MySQL 并 不 支持 多 重 WHERE， 但 是 可 以 使 用 AND (和 ) 、OR CR) 这 两 个 关键 字 ， 把 多 
重 条 件 组 合 起 来 使 用 。 如 要 搜索 ID 号 为 1 和 ID 号 为 10 的 用 户 的 记录 就 可 以 使 用 : 

select * from table name where id=1 or id=10 

这 样 就 会 查询 出 所 需要 的 信息 。 同 理 AND 操作 是 同时 满足 两 个 条 件 的 内 容 才 会 被 查询 出 。 

WHERE 子 句 用 于 DELETE 操作 时 是 什么 情况 呢 ? 如 一 个 论坛 中 用 户 太 多 了 。 如 果 要 删除 连续 一 
年 没有 登录 的 用 户 《〈 一 般 是 没有 这 样 的 操作 的 ) 。 就 可 以 这 样 使 用 : 

delete from table_name where no_login>365; 

这 样 ， 未 登录 时 间 超 过 一 年 的 用 户 就 会 被 删除 。 

还 有 一 点 需要 注意 ，where 子 句 的 操作 符 不 仅 有 “=”、“<”、“>” 等 这 些 数学 符号 ， 还 可 以 使 
用 “not” 表 示 逻 辑 非 。 如 要 搜索 所 有 性 别 不 为 男 的 成 员 的 信息 就 可 以 使 用 这 样 的 格式 : 

select * from table_name where sex not male 

这 样 就 可 以 选 出 所 有 性 别 不 是 男 的 记录 。 

还 有 一 个 操作 符 LIKE 可 以 用 于 模糊 查询 。 它 的 使 用 格式 如 下 所 示 : 

select * from table_name where field_name like value 

其 中 的 field name 为 字段 〈 实 际 指 代 该 字段 的 值 ) ，value 为 某 一 个 值 。 这 样 的 使 用 是 检查 左边 的 
字段 的 值 field_name 是 否 为 右边 的 value 的 子 串 。 

另外 在 使 用 LIKE 操作 符 时 还 可 以 加 上 简单 的 通配符 “%”、“_”。 其 中 “%” 指 代 0 个 或 多 个 
字符 的 字符 串 ，“_” 指 代 何 一 个 单个 字符 。 这 样 就 可 以 通过 LIKE 的 模糊 查找 功能 找 出 包含 某 个 字 串 
的 记录 。 如 下 面 的 操作 : 


select * from table name where address like "% 北 京 %" 
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这 样 就 可 以 搜索 出 所 有 地 址 在 北京 的 用 户 或 者 地 址 中 包括 有 北京 内 容 的 用 户 的 记录 。 


至 此 
该 子 句 可 


14.5.2 


WHERE 子 句 就 为 读者 介绍 到 这 里 。 可 以 看 出 该 子 句 包 含 的 内 容 还 是 相当 广泛 的 。 善 于 利用 
以 大 大 的 提高 相关 SQL 语句 的 执行 效率 。 


使 用 LIMIT 子 句 对 结果 进行 分 页 显示 


在 使 用 SELECT 进行 查询 时 ， 如 果 表 中 的 结果 太 多 ， 可 能 就 会 查找 出 很 多 的 结果 。 如 果 只 是 想 要 
其 中 的 几 条 该 怎么 办 。 实 际 这 种 情况 常 出 现在 分 页 操作 中 。 如 一 个 留言 短 一 共有 100 条 记录 ， 如 果 只 


想 让 一 页 


出 现 10 条 记录 该 怎么 办 ? 这 时 就 要 用 到 LIMIT 子 句 。 


LIMIT iR 1 个 或 2 个 数字 参数 ， 如 果 给 定 2 个 参数 ， 第 1 个 指定 要 返回 的 第 1 行 的 偏 移 量 ， 第 2 


个 指定 返 


回 行 的 最 大 数目 。 注 意 初 始 行 的 偏 移 量 是 0〈 不 是 1) 。 它 的 使 用 格式 像 下 面 这 样 : 


select field nam from table name limit 10 


下 面 使 用 一 个 实例 来 说 明 使 用 limit 与 不 使 用 limit 的 区 别 〈 这 里 的 表 还 使 用 TEST1 表 ， 在 使 用 前 


使 用 前 面 的 14-10.php~14-12.php 给 表 中 加 入 记录 。 不 过 表 的 结构 在 14.4.7 小 节 中 被 改变 。 使 用 前 还 要 
再 改 回来 ) 。 
<html> 
<head> 
<title> 使 用 limit 子 名 </title> 
</head> 
<body> 
<center> 
<?php 
$db_host=localhost; /MySQL 服务 器 名 
$db_user=root; /MySQL 用 户 名 
$db_pass=""; /MySQL 用 户 对 应 密码 
$db_name="test"; // 要 操作 的 数据 库 


/使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 返 回 相应 信息 
$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 


mysql_select_db($db_name,$link); // 选 择 相应 的 数据 库 ， 这 里 选择 test 库 
$sql="select * from test1"; // 没 有 加 入 limit 的 SQL 语句 
Sresult=mysql_query($sql,$link); /使 用 mysql_query() 发 送 SQL 请 求 
echo "没有 使 用 limit 子 句 的 输出 结果 : "; 

echo "<p>"; 

echo "<table border=1>"; /使 用 表格 格式 化 数据 

echo "<tr><td>ID</td><td> 姓 名 </td><td> 邮 箱 </td><td> 电 话 </td><td> 地 址 </td></tr>"; 


while($row=mysql_fetch_array($result) INRA SQL 语句 执行 结果 把 值 赋 给 数组 


{ 


echo "<tr>"; 

echo "<td>".$row[id]."</td>"; /显示 ID 
echo "<td>".$row[name]." </td>"; /显示 姓名 
echo "<td>". $row[mail]." </td>"; // 显 示 邮 箱 
echo "<td>". $row[phone]." </td>"; /显示 电话 


echo "<td>".$row[address]." </td>"; /显示 地 址 
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echo "</tr>"; 
echo "</table>"; 
echo "<p>"; 
echo "使 用 limit 子 句 后 的 输出 结果 : "; 
echo "<p>"; 
$sql="select * from test1 limit 3"; // 加 入 limit 子 句 的 sql 语句 
$result=mysql_query($sql,$link); IHEM mysql_query() 发 送 SQL 请 求 
echo "<table border=1>"; // 使 用 表格 格式 化 数据 
echo "<tr><td>ID</td><td> 姓 名 </td><td> 邮 箱 </td><td> 电 话 </td><td> 地 址 </td></tr>"; 
while($row=mysql_fetch_array($result)) // 遍 历 SQL 语句 执行 结果 把 值 赋 给 数组 
{ 


echo "<tr>"; 
echo "<td>". $row[id]."</td>"; IRF ID 
echo "<td>".$row[name]." </td>"; /显示 姓名 
echo "<td>".$row[mail]." </td>"; /显示 邮箱 
echo "<td>".$row[phone]." </td>"; /显示 电话 
echo "<td>".$row[address]." </td>"; /显示 地 址 
echo "</tr>"; 

} 

echo "</table>"; 

?> 

</center> 

</body> 

</html> 


把 以 上 代码 保存 为 “14-19.php”。 然 后 在 PHP 执行 环境 中 运行 该 文件 ， 执 行 结果 如 图 14.19 所 示 。 

现在 再 对 14-19.php 的 代码 做 小 小 的 改动 ， 把 limit 子 句 后 面 的 参数 3 改 为 23。 即 把 原来 的 一 个 参 
数 变 为 两 个 参数 。 第 1 个 参数 2 为 偏 移 量 ， 第 2 参数 3 为 显示 的 结果 。 然 后 再 来 执行 14-19.php， 执 行 
结果 将 会 如 图 14.20 所 示 。 


O KRW IAD WHU s æ] Li 
没有 使 用 limit 子 句 的 笨 出 结果 ， F 没有 使 用 linit 子 句 的 输出 结果 ， > 
ID 姓名 ”邮箱 EA [ID 姓名 | 邮箱 电话 


2 李 四 lisi@mircosoft. com|2345678 
3 EE wangmuBtom.com |1234567 
4 ÆA |zhaolin8126. com (1111111 
5 陈 小 二 |xiaoer@sohu com [2222222 
6 赵 匡 局 jkuangyin8125. com ”没有 MERER 


使 用 limit 子 句 后 的 输出 结果 


2 ÆN 1isi@mircosoft. com|2345678 | 北京 
B 王 五 “wangwugtom com [1234567 HATE 
a ÈA [zhaolinðl26.com (1111111 ER TARRE 
5 陈 小 二 |xiaoer@sohu com (2222222 河南 省 

6 赵 匡 岂 kuangyine125. com 没有 ”| 北宋 东京 


使 用 1imit 子 名 后 的 输出 结果 : 


Ta 邮箱 电话 ”| 地 址 
isiOmircosoft. com|2345678 [北京 市 海淀 区 
3 |[ 王 五 wangmuBtom. com ”|1234567 HETE 
4 起 六 |zhaolin8126. com [1111111 [北京 市 东城 区 


miz WA 电话 ”地址 

a 起 六 ”|zhaolin8126. com (1111111 | 北京 市 东城 区 
5 陈 小 二 |xiaoer@sohu. com |2222222 河南 省 

6 EEH kuangyinðl26. com| 没 有 “| 北宋 东京 


到 
BE [到 LI Dee YA 


14.19 ”使 用 limit 子 句 执行 结果 图 14.20 ”使 用 limit 子 句 加 两 个 参数 的 执行 结果 


| 
YA 


周二 aali | | | internet 
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比较 两 次 的 执行 结果 可 以 明显 看 出 用 不 用 LIMIT 子 句 的 显示 区 别 。 不 使 用 子 句 将 显示 所 有 记录 ， 
而 使 用 子 句 后 将 显示 指定 条 数 的 记录 。 加 入 一 个 参数 只 显示 指定 条 数 记录 ， 加 入 两 个 参数 把 搜索 结果 
按 第 1 个 参数 进行 偏 移 ， 再 显示 指定 条 数 的 记录 。 


14.5.3 ”使 用 ORDER BY 对 查询 结果 进行 排序 


使 用 SELECT 语句 对 数据 表 进 行 浏览 查询 ， 所 查 出 的 记录 都 是 按照 记录 插入 的 先后 顺序 排列 的 。 
有 时 这 样 的 结果 并 不 是 用 户 所 希望 的 。 如 果 希 望 结果 按照 某 一 字段 的 某 一 顺序 进行 排列 这 时 就 需要 用 
到 ORDER BY 子 句 。 该 子 句 的 使 用 格式 如 下 所 示 : 

select field_nam from table_name order by field_name desc 

其 中 的 field_name 为 字段 ，table_name 为 表 名 。 参 数 desc 为 降序 即 从 大 到 小 的 顺序 排列 ， 如 果 要 
使 用 升序 即 从 大 到 小 的 顺序 排列 就 要 使 用 参数 asc。 如 果 不 使 用 参数 ， 默 认为 按照 升序 进行 排序 。 如 对 
K testl 中 的 记录 按 电话 号 码 一 项 按 降序 排列 就 可 以 这 样 使 用 : 

select * from test1 order by phone desc; 

下 面 通过 一 个 实例 来 看 一 下 如 何 使 用 order by 子 句 对 查询 结果 进行 排序 。 具 体内 容 参 看 以 下 代码 : 


<html> 

<head> 

<title> 使 用 order by 子 句 </title> 

</head> 

<body> 

<center> 

<?php 

$db_host=localhost; /MySQL 服务 器 名 
$db_user=root; /MySQL 用 户 名 
$db_pass=""; /MySQL 用 户 对 应 密码 
$db_name="test"; // 要 操作 的 数据 库 
/使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 返 回 相应 信息 
$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 


mysql_select_db($db_name,$link); // 选 择 相应 的 数据 库 ， 这 里 选择 test 库 
$sql="select * from test1"; // 没 有 加 入 limit 的 SQL 语句 
$result=mysql_query($sql,$link); /使 用 mysql_query() 发 送 SQL 请 求 
echo "没有 使 用 order by 子 句 的 输出 结果 : "; 
echo "<p>"; 
echo "<table border=1>"; /使 用 表格 格式 化 数据 
echo "<tr><td>ID</td><td> 姓 名 </td><td> 邮 箱 </td><td> 电 话 </td><td> 地 址 </td></tr>"; 
while($row=mysql_fetch_array($result) IRA SQL 语句 执行 结果 把 值 赋 给 数组 
{ 

echo "<tr>"; 

echo "<td>". $row[id]."</td>"; /显示 ID 

echo "<td>".$row[name]." </td>"; /显示 姓名 

echo "<td>". $row[mail]." </td>"; // 显 示 邮 箱 

echo "<td>". $row[phone]." </td>"; /显示 电话 


echo "<td>".$row[address]." </td>"; /显示 地 址 
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echo "</tr>"; 
} 
echo "</table>"; 
echo "<p>"; 
echo "使 用 order by 子 句 后 的 输出 结果 : "; 
echo "<p>"; 
$sql="select * from test1 order by phone"; // 加 入 order by 子 句 的 sql 语句 
$result=mysql_query($sql,$link); /使 用 mysql_query() 发 送 SQL 请 求 
echo "<table border=1>"; // 使 用 表格 格式 化 数据 
echo "<tr><td>ID</td><td> 姓 名 </td><td> 邮 箱 </td><td> 电 话 </td><td> 地 址 </td></tr>"; 
while($row=mysql_fetch_array($result)) /遍历 SQL 语句 执行 结果 把 值 赋 给 数组 


echo "<tr>"; 
echo "<td>". $row[id]."</td>"; IRR ID 
echo "<td>".$row[name]." </td>"; /显示 姓名 
echo "<td>".$row[mail]." </td>"; /显示 邮箱 
echo "<td>".$row[phone]." </td>"; /显示 电话 
echo "<td>".$row[address]." </td>"; /显示 地 址 
echo "</tr>"; 

} 

echo "</table>"; 

?> 

</center> 

</body> 

</html> 


把 以 上 代码 保存 为 “14-20.php”。 然 后 在 PHP 执行 环境 中 运行 该 文件 ， 执行 结 果 如 图 14.21 所 示 。 
查看 图 14.21 的 执行 结果 ， 可 以 看 出 ， 下 部 的 输出 结果 是 按照 所 有 记录 的 电话 升序 进行 排序 。 
现在 把 上 例 中 的 ORDER BY 子 句 后 面 加 上 参数 desc。 再 次 执行 ， 结 果 会 如 图 14.22 所 示 。 


沪 使 用 rder_hy 子 句 - Microsoft Internet Explorer io 
XO REO SEV KRA IAD WHW Li 
E| 
没有 使 用 order by 子 句 的 输出 结果 ， 
DRZ WA Géi 电话 
2 ÆN lisi@mircosoft. com ] iisigmircosost, com|2345678 
3 [EE 五 wangwuftom. com [EE WangewuBtom com (1234567 
4 起 六 |zhaolin@126. com ÆA [zhaolin®126. com [1111111 
5 际 不 三 [xiaoer@sohu. com ”|2222222 河南 省 陈 小 二 [xiaoer8@sohu. com ”|2222222 河南 省 
6 起 匡 风 Ikuangyin8126. com RA ”| 北宋 东京 EEM kuangyin8126.com RA ”| 北宋 东京 
使 用 order by 子 名 后 的 输出 结果 ， 使 用 order by 二 名 后 的 输出 结果 ， 
mpa | 邮箱 电话 miz 邮箱 电话 [地址 
4 起 入 [zhaolin®126.com |1111111| e EK kuangyinðl26.com 没有 ”| 北宋 东京 
3 | 王 五 ”wangmuBtom. com [1234567 草 省 市 区 街 2 ÆN [lisið@mircosot. com|2345678 北京 市 海淀 区 
5 陈 小 二 [xiaoer@sohu. com [2222222 阿南 省 5 陈 小 二 [xiaoeraschu. com ”|2222222 河南 省 
2 ÆA [lisiðmircosoft. com|2345678 [北京 市 海淀 区 3 压 五 ”wangwuatom com [1234567 REMEE 
6 EM kuangyingi26.cm RA MRRR a EA [zhaolin®l26.com [1111 | 北京 市 东城 区 
zi g 
[Ea I ll EF ZI Ea Ti ternet á 


14.21 使 用 order by 子 句 执行 结果 图 14.22 加 上 desc 参数 后 的 执行 结果 
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而 图 14.22 的 执行 结果 则 显示 ， 下 部 的 输出 按 所 有 记录 的 电话 进行 降序 排列 。 

从 以 上 两 次 执行 结果 图 中 可 以 清晰 的 看 出 ， 使 用 ORDER BY 子 句 与 不 使 用 该 子 句 的 区 别 。 

另外 在 使 用 ORDER BY 子 句 时 有 一 项 需要 注意 ，ORDER DY 子 句 允许 多 次 使 用 。 这 样 就 可 以 实 
现 多 重 排序 。 就 像 下 面 这 样 : 


select field nam from table name order by field_name,order by field_name2 


如 何 理解 呢 ? 就 是 说 ， 先 对 查询 结果 按照 field_name 字段 按 升 序 进行 排列 ， 如 果 有 多 个 记录 它们 
的 field name 字段 都 相同 ， 这 时 再 按照 field_name2 字段 按 升 序 进行 排列 。 这 就 是 多 重 排序 。 比 如 说 对 
某 个 班级 的 学 生成 绩 先 按照 总 成 绩 进 行 排序 ， 以 排出 名 次 。 如 果 两 个 学 生 的 总 成 绩 都 相同 ， 再 按照 语 
文 的 成 绩 进 行 排序 。 

当然 也 可 以 使 用 3 种 甚至 多 种 排序 。 即 ORDER BY 子 句 可 以 多 次 使 用 。 

高 级 查询 的 内 容 ， 到 这 里 也 就 为 读者 介绍 完了 。 利 用 本 节 介绍 的 几 种 高 级 查询 子 句 一 是 可 以 提高 
SQL 语句 执行 效率 ， 另 外 还 可 以 结合 不 同 的 功能 扩展 SQL 语句 的 功能 。 


14.6. MySQL 数据 库 使 用 实例 


14.6.1 明确 设计 目的 一 一 学 生 档案 管理 

这 一 节 ， 结 合 本 章 所 学 MySQL 数据 库 的 内 容 ， 来 做 一 个 实际 使 用 的 例子 。 制 作 一 个 学 生 档案 管 
理 系统 。 

一 个 班级 学 生 档案 管理 系统 必 备 的 功能 就 是 对 学 生 信 息 的 管理 ， 包 括 添加 信息 、 浏 览 信息 、 修 改 
信息 、 删 除 信息 等 操作 。 

这 里 先 建立 一 个 表 student 以 存放 学 生 的 信息 。 该 表 中 有 以 下 字段 , ID (记录 号 ) NAME (姓名 ) 、 
SEX (性别 ) ~ BIRTHDAY (出 生日 期 ) 、S_ID (学 号 ) 、PARENT (家 长 姓名 ) 、PHONE (家 庭 电 
话 ) 、ADDRESS 家庭 地 址 ) 等 。 

把 一 些 变量 存 为 一 个 配置 文件 中 ， 以 便 多 次 调用 ， 该 文件 命名 为 14-21.php。 其 内 容 如 下 所 示 : 


<?php 

$host_name="localhost"; NEZ 
$db_user="root"; /用 户 名 
$db_pass=""; /用 户 密 码 
$db_name="test"; /数据库 名 
S$table_name="student"; /数据 表 名 
S$list_num=10; /| 每 页 显示 记录 数 
?> 


该 文件 存放 了 连接 数据 库 时 必须 的 各 项 内 容 ， 这 样 需要 时 只 需 使 用 include0 或 者 require 调用 该 文 
件 即 可 ， 避 免 了 多 次 定义 。 
准备 工作 这 一 小 节 就 介绍 到 这 里 。 从 14.6.2 节 开 始 具体 的 设计 工作 。 
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14.6.2 连接 MySQL 服务 器 建立 学 生 档案 表 


这 一 节 来 介绍 连接 到 服务 器 创建 学 生 档案 表 student。 具 体内 容 参看 以 下 代码 : 


<? 

require "14-21.php"; // 调 用 配置 文件 

/连接 MySQL 服务 器 

$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
mysql_select_db($db_name,$link); /| 选择 test 数据 库 


/下 面 的 $sql 就 为 创建 表 的 SQL 语句 
$sql="create table $table name( 
id int(5) not null auto increment primary key, 
name varchar(12) not null, 
sex varchar(4) not null, 
birthday varchar(16) not null, 
Ss id varchar(10) not null, 
parent varchar(12) not null, 
phone varchar(14) not null, 
address varchar(30) not null 
ys 


if(mysql_query($sql,$link)) /发 送 SQL 语句 执行 创建 表 的 操作 

echo " 表 ".$table_name." 创 建成 功 "; 1/ 如果 创 建成 功 显示 信息 

else 

echo "创建 数据 库 出 错 ! "; 

?> 

把 以 上 代码 保存 为 “14-22.php”。 然 后 在 PHP 执行 环境 中 运行 该 文件 ， 将 会 出 现 如 图 14.23 所 示 
的 执行 结果 。 JA mtt 7127 0.0. 1714-22 ka ornet RAIAT- TF7] 

创建 表 是 建立 系统 的 基础 ， 其 他 一 切 操作 都 要 在 N = i 
表 中 进行 。 表 创建 完成 后 ， 下 一 步 就 是 为 表 中 添加 相 a 有 
应 的 数据 了 。14.6.3 小 节 将 介绍 显示 数据 页 面 及 添加 SE [li EC Z 
数据 页 面 的 创建 过 程 。 图 14.23 ”建立 学 生 档案 表 执行 结果 


14.6.3 ”显示 学 生 数 据 页 的 创建 


这 一 小 节 为 读者 介绍 如 何 显示 表 中 的 数据 。 

显示 数据 当然 还 是 要 使 用 SELECT 查询 ， 但 这 一 小 节 的 SELECT 查询 不 同 于 前 面 介 绍 的 内 容 。 这 
一 节 所 使 用 的 SELECT 查询 包括 更 多 的 内 容 ， 最 重要 的 一 项 就 是 使 用 LIMIT 子 语句 以 实现 分 页 功能 。 

<7 

require "14-21.php"; // 调 用 配置 文件 

if(!$_GET[page]) 

$page=1; 

else 

$page=$_GET[page]; 
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// 连 接 MySQL 服务 器 

$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
mysql_select_db($db_name, $link); /选择 test 数据 库 

/下 面 的 $sql 就 为 创建 表 的 SQL 语句 

$sql="select id from $table name"; /查询 所 有 记录 
$result=mysql_query($sql,$link); // 发 送 SQL 请 求 
$num=mysql_num_rows(S$result); // 获 得 记录 数 

?> 

<html> 

<head> 

<title> 学 生 档案 管理 系统 一 一 记录 显示 页 </title> 

</head. 

<body> 

<center> 

<h1> 学 生 档案 管理 系统 一 一 记录 显示 页 </h1> 

<p> 

<a href=14-24.php> 添 加 记录 </a>&nbsp; &nbsp;<a href=14-26.php> 查 找 记 录 </a> 

<p> 

<? 

echo "目前 共有 ".$num." 条 记录 &nbsp;&nbsp;"; // 输 出 记录 数 
$p_count=ceil($num/$list_num); /| 总 页 数 为 总 条 数 除 以 每 页 显示 数 
echo " 共 分 ".$p_count." 页 显示 &nbsp;&nbsp;"; // 输 出 页 数 

echo "当前 显示 第 ".$page." 页 "; 

echo "<p>"; 

if($num>0) // 如 果 记 录 数 大 于 0 输出 记录 内 容 
{ 


?> 

<p> 

<table border="1"> 

<tr> 

<td>ID</td> 

<td> 姓 名 </td> 

<td> 性 别 </td> 

<td> 出 生日 期 </td> 
<td> 学 号 </td> 

<td> 家 长 姓名 </td> 

<td> 家 庭 电话 </td> 
<td> 家 庭 住 址 </td> 
<td>&nbsp;</td> 

</tr> 

<? 
S$temp=($page-1)*S$list_num; 
$sql="select * from $table name limit $temp,$list num"; 


$result=mysql_query($sql); // 执 行 SQL 语句 
while($row=mysql_fetch_array($result)) // 通 过 循环 遍历 记录 集 
{ 


echo "<tr>\n"; 
echo "<td>".$row[id]."</td>\n"; 
echo "<td>".$row[name]."</td>\n"; 
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echo "<td>".$row[sex]."</td>\n"; 

echo "<td>".$row[birthday]."</td>\n"; 

echo "<td>".$row[s_id]."</td>\n"; 

echo "<td>".$row[parent]."</td>\n"; 

echo "<td>".$row[phone]."</td>\n"; 

echo "<td>".$row[address]."</td>\n"; 

echo "<td><a href=14-25.php?id=".$row[id]."> 改 </a></td>\n"; 


echo "</tr>\n"; 
ie "</table>"; 
/以 下 为 显示 分 页 的 连接 的 内 容 
$prev page-$page-1; // 定 义 上 一 页 为 该 页 减 1 
$next_page=$page+1; /定义 下 一 页 为 该 页 加 1 
echo "<p align=\"centen"> "; 
if ($page<=1) // 如 果 当前 页 小 于 等 于 1 只 有 显示 
echo "第 一 页 |"; 
Le // 如 果 当 前 页 大 于 1 显示 指向 第 一 页 的 连接 
i echo "<a href='$_SERVER[PHP_SELF]?page=1'> 第 一 页 </a> |" 
i ($prev_page<1) // 如 果 上 一 页 小 于 1 只 显示 文字 
echo "上 一 页 | "; 
// 如 果 大 于 1 显示 指向 上 一 页 的 连接 
echo "<a href='$_SERVERI[PHP_SELP]?page=$prev_page'> 上 一 页 </a> | "; 
i ($next_page>$p_count) // 如 果 下 一 页 大 于 总 页 数 只 显示 文字 
echo "下 一 页 | "; 
PE // 如 果 小 于 总 页 数 则 显示 指向 下 一 页 的 连接 
echo "<a href='$_SERVER[PHP_SELF]?page=$next_page'> 下 一 页 </a> | "; 
($page>=$p_count) // 和 如果 当前 页 大 于 或 者 等 于 总 页 数 只 显示 文字 
| echo "最 后 一 页 </p>\n"; 
YA // 如 果 当 前 页 小 于 总 页 数 显 示 最 后 页 的 连接 
echo "<a href='$_SERVER[PHP_SELF]?page=$p_count> 最 后 一 页 </a></p>\n"; 
YA // 如 果 没有 记录 时 输出 信息 


echo "暂时 还 没有 记录 !"; 
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} 


?> 
</body> 
</html> 


把 以 上 代码 保存 为 “14-23.php”， 以 备 后 用 。 

可 以 看 出 ，14-23.php 中 的 SELECT 与 前 几 节 介 绍 的 略 有 不 同 ， 不 同 之 处 就 在 于 它 使 用 了 LIMIT 
的 两 个 参数 。 第 1 个 参数 为 返回 查询 的 偏 移 量 ， 第 2 个 参数 为 显示 的 记录 数 。 记 录 数 很 简单 ， 直 接 限 
制 为 每 页 最 多 显示 数 就 可 以 了 。 而 偏 移 量 怎么 计算 呢 ? 如 当前 页 为 第 1 页 ， 偏 移 量 为 0 就 可 以 了 ; 当 
前 页 为 第 2 页 ， 偏 移 量 就 为 10; 当前 页 为 第 3 页 ， 偏 移 量 就 为 20…… 以 此 类 推 。 如 果 当 前 页 为 N， 偏 
HEMA C CN-1) *$list num) 即 前 面 页 面 显 示 的 所 有 记录 数 ， 这 样 就 实现 了 分 页 的 显示 。 


14.6.4 添加 记录 页 的 创建 


由 于 表 中 还 没有 记录 ,所 以 在 执行 14-23.php 时 会 得 到 没有 记录 的 结果 。 这 一 节 就 开始 着 手 来 为 表 
中 添加 记录 。 这 里 还 是 采用 前 台 输 入 加 后 台 处 理 的 方式 来 进行 。 不 过 这 一 小 节 ， 把 这 前 台 的 表单 输入 
和 后 台 的 数据 处 理 整合 到 一 个 文件 中 ， 以 使 程序 更 加 简洁 。 具 体内 容 请 参看 以 下 代码 ; 


<? 

if(!$_POST[name]) // 如 果 没 有 记录 输入 
{ 

?> 

<html> 

<head> 

<title> 学 生 档案 管理 系统 一 一 记录 添加 页 </title> 
</head. 

<body> 

<script language="javascript"> 

function Juge(theForm) 


if (theForm.name.value =="" 


alert(" 请 输入 姓名 !"); 
theForm.name.focus(); 
retum (false); 


} 


if (theForm.s_id.value == "" 


alert(" 请 输入 学 号 !"); 
theForm.s_id.focus(); 
retum (false); 
} 
I 
</script> 
<center> 


<h1> 学 生 档 案 管 理 系统 一 一 记录 添加 页 </h1> 
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<a href="14-23.php"> 返 回首 页 </a> 

<table border=1> 

<form action="<?echo $PATH_INFO?>" method="post" onsubmit="retum Juge(this)"> 
<tr> 

<td> 输 入 姓名 : </td> 

<td><input name="name" type="text"></td> 

</tr> 

<tr> 

<td> 输 入 性 别 : </td> 

<td> 

<input type=radio name=sex value= 男 checked> 男 
<input type=radio name=sex value= 女 > 女 

</td> 

</tr> 

<tr> 

<td> 出 生日 期 : </td> 

<td> 

<select name=b_y> 

<? 

for($i=1980;$i<2004;$i++) // 循 环 输出 出 生年 
echo "<option value=".$i.">".$i."\n"; 

?> 

</select> 年 

<select name=b_m> 

<? 

for($i=1;$i<13;$i++) // 循 环 输出 出 生 月 
echo "<option value=".$i.">".$i."\n"; 

?> 

</select> 月 

<select name=b_d> 

<? 

for($i=1;$i<32;$i++) // 循 环 输出 出 生日 
echo "<option value=".$i.">".$i."\n"; 

?> 

</select> H 

</td> 

</tr> 

<tr> 

<td> 输 入 学 号 ;</td> 

<td><input name="s_id" type="text"></td> 

</tr> 

<tr> 

<td> 监 护 人 姓名 :</td> 

<td><input name="parent" type="text"></td> 

</tr> 

<tr> 

<td> 家 庭 电 话 : </td> 

<td><input name="phone" type="text"></td> 

</tr> 
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<tr> 

<td> RREH: </td> 

<td><input name="address" type="text"></td> 

</tr> 

<tr> 

<td colspan="2"><center><input type=submit value=" 确 认 提 交 "> 
<input type=reset value=" 重 新 选择 "></center></td> 
</tr> 

</form> 

</table> 

<? 

} 


else 


{ 

/以 下 内 容 为 获取 表单 传递 的 变量 
$name=$_POST[name]; 
$sex=$_POST[sex]; 
$birthday=$_POST[b_y]."#Æ".$_POST[b_m]."A".$_POST[b_d]." R"; 
$s id-$ POSTIs id); 
S$parent=$_POST[parent]; 
$phone=$_POST[phone]; 
$address=$_POST[address]; 
require "14-21.php"; 
$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 


mysql_select_db($db_name,$link); /| 选择 test 数据 库 
$sql="insert into $table name (name,sex,birthday,s_id,parent,phone,address) 

values('$name','$sex','$birthday','$s_id','$parent','$phone','$address')"; 
mysql_query($sql,$link); /执行 插入 记录 的 SQL 语句 

?> 

<html> 

<head> 

<title> 学 生 档 案 管理 系统 一 一 记录 添加 页 </title> 

</head> 

<meta http-equiv="refresh" content="2; url=14-23.php"> 

<body> 

已 经 成 功 添加 记录 ， 两 秒 后 返回 。 

</body> 

</html> 

<? 

} 

?> 


把 以 上 代码 保存 为 “14-24.php”， 以 备 后 用 。 


可 以 看 出 该 文件 与 前 面 对 表 进行 操作 时 的 例子 有 所 不 同 。 不 同 之 处 就 在 于 以 前 是 输入 数据 的 前 台 


与 处 理 数据 的 后 全 是 分 开 的 ， 是 不 同 的 两 个 文件 。 现 在 把 前 台 与 后 人 台 的 功能 整合 到 一 个 文件 中 了 。 则 


中 的 关键 就 是 表单 的 action 属性 要 指向 自身 。 这 里 使 用 了 PHP 的 系统 变量 SPATH_INFO 即 指 代 文件 
身 。 同 时 还 用 POST 变量 来 判断 前 后 台 操 作 。 如 果 没有 使 用 POST 变量 则 判定 为 前 台 添加 数据 操作 
如 果 有 了 POST 变量 则 判断 为 后 台 处 理 添 加 数据 的 操作 。 


自 


, 
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14.6.5 ”修改 记录 页 的 创建 


文件 14-23.php 中 有 一 个 指向 14-25.php 的 连接 ， 该 文件 的 作用 就 是 对 原 有 的 数据 进行 修改 。 这 一 
节 就 来 创建 这 个 修改 原 有 记录 的 文件 。 同 14.6.4 节 一 样 ， 这 个 文件 仍然 把 前 台 输 入 修改 内 容 与 后 台 处 
理 修 改 结果 整合 为 一 个 文件 。 具 体内 容 参 看 以 下 代码 : 


<? 

if(!$_POST[name]) // 如 果 没 有 记录 输入 
{ 

?> 

<html> 

<head> 

<title> 学 生 档案 管理 系统 一 一 记录 修改 页 </title> 
</head. 

<body> 

<script language="javascript"> 

function Juge(theForm) 


if (theForm.name.value == "") 


alert(" 请 输入 姓名 ! "); 
theForm.name.focus(); 
retum (false); 


if (theForm.s_id.value == "") 


alert(" 请 输入 学 号 ! "); 
theForm.s_id.focus(); 
retum (false); 


} 


</script> 

<center> 

<h1> 学 生 档案 管理 系统 一 一 记录 修改 页 </h1> 

<a href="14-23.php"> 返 回首 页 </a> 

<table border=1> 

<form action="<?echo $PATH_INFO?>" method="post" onsubmit="return Juge(this)"> 
<? 

if(!$_GET][id]) 


echo "没有 选择 ID 18"; 


exit(); 
else 


$id=$_GETT[id]; 
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reguire "14-21.php"; 


$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 


mysql_select_db($db_name,$link); 

$sql="select * from $table name where id='$id"; 
$result=mysql_query($sql,$link); 
$row=mysql_fetch_array($result); 

$temp-$rowl birthday); 

/以 下 代码 为 通过 不 同情 况 分 离 出 出 生 的 年 月 日 
$b_y=substr($temp,0,4); 

if(strrpos($temp," 月 ")=="7") 


{ 
$b_m=substr($temp,6,1); 
if(strrpos($temp," A")=="10") 
{ 

$b_d=substr($temp,9,1); 

} 
else 
$b_d=substr($temp,9,2); 

} 

else 

{ 
$b_m=substr($temp,6,2); 
if(strrpos($temp," A ")=="11") 
{ 

$b_d=substr($temp, 10,1); 

} 
else 
$b_d=substr($temp,10,2); 

} 

?> 

<tr> 


<td> 输 入 姓名 : </td> 


// 选 择 test 数据 库 
/创建 SQL 语句 

/| 执行 SQL 查询 

// 获 取 数 组 

// 把 出 生日 期 赋值 给 变量 


// 从 出 生日 期 中 提取 年 
// 查 找 月 的 位 置 以 判断 月 份 的 位 数 


// 从 出 生日 期 中 提取 出 月 
// 查 找 日 的 位 置 以 判断 日 期 的 位 数 


// 从 出 生日 期 中 提取 出 日 


/从 出 生日 期 中 提取 出 日 


<td><input name="name" type="text" value="<?echo $row[name]?>"></td> 


</tr> 
<tr> 
<td> 输 入 性 别 :</td> 
<td> 


<input type=radio name=sex value= 男 <? if ($row[sex]==" 男 ") echo "checked"?>> 男 
<input type=radio name=sex value= 女 <? if ($row[sex]==" 女 ") echo "checked"?>> 女 


</td> 

</tr> 

<tr> 

<td> 出 生日 期 : </td> 

<td> 

<select name=b_y> 

<? 
for($i=1980;$i<2004;$i++) 
1 


echo "<option value=".$i; 


// 循 环 输出 出 生年 
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if($b_y==$i) echo " selected=1"; 
echo ">".$i."\n"; 
} 
?> 
</select> 年 
<select name=b_m> 
<? 
for($i=1;$i<14;$i++) // 循 环 输出 出 生 月 
{ 
echo "<option value=".$i; 
if($b_m==$i) echo " selected=1"; 
echo ">".$i."\n"; 
} 
?> 
</select> 月 
<select name=b_d> 
<? 
for($i=1;$i<32;$i++) // 循 环 输出 出 生日 
{ 
echo "<option value=".$i; 
if($b_d==$i) echo " selected=1"; 
echo ">".$i."\n"; 
} 
?> 
</select> A 
</td> 
</tr> 
<tr> 
<td> 输 入 学 号 ;</td> 
<td><input name="s_id" type="text" value="<?echo $row[s_id]?>"></td> 
</tr> 
<tr> 
<td> 监 护 人 姓名 :</td> 
<td><input name="parent" type="text" value="<?echo $row[parent]?>"></td> 
</tr> 
<tr> 
<td> 家 庭 电话 : </td> 
<td><input name="phone" type="text" value="<?echo $row[phone]?>"></td> 
</tr> 
<tr> 
<td> 家 庭 住 址 :</td> 
<td><input name="address" type="text" value="<?echo $row[address]?>"></td> 
</tr> 
<tr> 
<td colspan="2"><center><input type=submit value=" 确 认 提交 "> 
<input type=reset value=" 重 新 选择 "></center></td> 
</tr> 
</form> 
</table> 
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<? 


3 


else 


{ 

/以 下 内 容 为 获取 表单 传递 的 变量 
$name=$_POST[name]; 
$sex=$_POST[sex]; 
$birthday=$_POST[b_y]."#".$_POST[b_m]." A".$_POST[b_d]." A"; 
$s_id=$_POST[s_id]; 
$parent=$_POST[parent]; 
$phone=$_POST[phone]; 
$address=$_POST[address]; 
require "14-21.php"; 
$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 


mysql_select_db($db_name,$link); /| 选择 test 数据 库 
$sql="update Stable_name set 
name-'$name',ser-'$sev',birthday-'$birthday',s id-'$s id',parent-'$parent',phone-'$phone',address-'$addres 
s"; 
mysql_query($sql,$link); /执行 更 新 记录 的 SQL 语句 
?> 
<html> 
<head> 
<title> 学 生 档案 管理 系统 一 一 记录 添加 页 </title> 
</head> 
<meta http-equiv="refresh" content="2; url=14-23.php"> 
<body> 
已 经 成 功 更 改 记 录 ， 两 秒 后 返回 。 
</body> 
</html> 
<? 
} 
?> 


把 以 上 代码 保存 为 “14-25.php”， 以 备 后 用 。 

该 文件 的 一 个 特征 是 把 修改 记录 的 前 台 输 入 内 容 与 后 台 处 理 数 据 结 合 了 起 来 。 但 这 里 还 存在 一 个 
问题 。 在 输入 学 生 的 出 生日 期 时 ， 把 输入 记录 格式 化 后 存 入 表 中 ， 当 需要 修改 时 ， 如 果 要 求 显示 原来 
的 出 生日 期 ， 就 必须 把 原来 的 数据 还 原 。 这 里 用 了 比较 第 一 点 的 方法 按 位 数 分 别提 取出 年 、 月 、 日 来 
实现 。 其 实 如 果 在 创建 表 时 把 出 生年 、 月 、 日 分 别 创建 成 字段 就 不 会 有 这 样 的 问题 存在 了 。 


14.6.6 ”查找 记录 页 的 创建 


如 果 班 级 学 生 的 人 数 特别 多 ， 记 录 分 了 好 多 页 显示 。 要 从 表 中 查找 某 一 条 或 几 条 特定 的 记录 是 相 
当 困 难 的 。 所 以 ， 有 必要 创建 一 个 查找 记录 的 页 面 。 这 一 节 就 来 设计 该 页 面 。 该 页 面 首先 让 用 户 选择 
查找 记录 所 依据 的 条 件 ， 然 后 ， 输 入 该 条 件 的 内 容 。 如 用 户 先 选择 学 号 ， 再 输入 学 号 的 内 容 如 
“200602003”， 然 后 就 把 结果 交 给 后 台 来 处 理 了 。 同 14.6.4 节 和 14.6.5 节 一 样 ， 查 找 记 录 的 页 面 ， 依 
然 采 用 前 台 与 后 台 整 合 在 一 起 的 模式 。 具 体内 容 请 参见 以 下 代码 : 
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<html> 
<head> 
<title> 学 生 档案 管理 系统 一 一 记录 查找 页 </title> 
</head> 
<body 3 
<center> 
<h1> 学 生 档案 管理 系统 一 一 记录 查找 </h1> 
<p> 
<a href=14-23.php> 返 回 </a> 
<p> 
<? 
if(!$_POST["find_v"]) // 如 果 没 有 查找 类 别 ， 则 显示 HTML 内 容 
{ 
?> 
<script language="javascript"> 
function Juge(theForm) 
{ 
if (theForm .find_v.value == "") 
{ 
alert(" 请 输入 查询 内 容 ! "); 
theForm.find_v.focus(); 
retum (false); 
} 
} 
</script> 
<table border="1"> 
<form action=<?echo $PATH_INFO?> method="post" onsubmit-"retum Juge(this)"> 
<tr> 
<td> 选 择 查 询 类 别 : </td> 
<td><select name="find_t"> 
<option value=name> 姓 名 </option> 
<option value=s_id> 学 号 </option> 
<option value=birthday> 出 生日 期 </option> 
<option value=parent> 监 护 人 </option> 
<option value=phone> 电 话 </option> 
<option value=address> 住 址 </option> 
</select></td> 
</tr> 
<tr> 
<td> 输 入 查询 内 容 : </td> 
<td><input type=text name="find_v"></td> 
</tr> 
<tr> 
<td colspan=2><center><input type=submit value= 确 认 提交 > 
<input type=reset value= 重 新 填写 ></center></td> 
</tr> 
</table> 
</center> 
<? 
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} 

else 

{ 

require "14-21.php"; // 调 用 配置 文件 
$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
mysql_select_ db($db_name,$link); // 选 择 test 数据 库 


$strsql="select*from $table name where $ POSTIfind _t] like '$_POST[find_v]"; 
$result=mysql_query($strsql,$link) or die(mysql_error()); 
$amount=mysql_num_rows($result); 
if($amount=="0") echo "<p> 没 有 记录 "; /如果 没有 找到 匹配 记录 ， 则 输出 提示 
else 
{ 
?> 
<h3> 下 面 是 查 出 来 的 结果 </h3> 
<p> 
<table border=1> 
<tr> 
<td>ID</td> 
<td> 姓 名 </td> 
<td> 性 别 </td> 
<td> 出 年 日 期 </td> 
<td> 学 号 </td> 
<td> 监 护 人 </td> 
<td> 电 话 </td> 
<td> 地 址 </td> 
</tr> 
<? 
while($row=mysql_fetch_array($result)) 
{ 
echo "<tr> 
<td>".$row["id"]."</td> 
<td>".$row["name"]."</td> 
<td>".$row["sex"]."</td> 
<td>".$row["birthday"]."</td> 
<td>".$row["s_id"]."</td> 
<td>".$row["parent"]."</td> 
<td>".$row["phone"]."</td> 
<td>".$row["address"]."</td> 
</tr>"; 
} 
echo "</table></center>"; 
} 
} 
?> 
</body> 
</html> 


把 以 上 代码 保存 为 “14-26.php”， 以 备 后 用 。 
该 文件 有 两 个 要 点 。 一 个 是 使 用 了 WHERE 子 句 ， 另 外 一 个 是 使 月 


了 WHERE 子 句 的 LIKE 操作 
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符 。 即 带 条 件 的 模糊 查找 。 这 样 虽然 降低 了 查找 精度 ， 但 却 提高 了 查找 的 准确 性 。 
随 着 该 文件 的 创建 完毕 ， 该 学 生 档案 管理 系统 ， 也 基本 上 成 型 了 。 下 面 就 来 实际 地 测试 一 下 该 系 
统 的 使 用 情况 ， 以 排除 BUG。 


14.6.7 ”学 生 档 案 管理 系统 实际 使 用 


由 于 表 已 经 在 14.6.2 小 节 创 建 完毕 , 所 以 , 直接 从 14-23.php 开始 执行 。 由 于 表 中 并 没有 任何 记录 ， 
所 以 是 首次 执行 该 系统 ， 其 执行 结果 将 会 如 图 14.24 所 示 。 
(1) 单 击 “ 添 加 记录 ”链接 后 ， 执 行 14-24.php， 出 现 如 图 14.25 所 示 的 执行 结果 。 
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图 14.24 记录 显示 页 第 1 次 执行 结果 图 14.25 执行 记录 添加 页 执行 结果 


(2) 这 里 ， 按 要 求 填 入 适当 的 学 生 信息 。 如 比 利 、 男 、1999 年 5 20H, 200601001, KEF 
1234567、 东 区 十 三 街 28 号 。 输 入 内 容 后 ， 单 击 “ 确 认 提交 ”按钮 。 由 于 系统 在 处 理 完 提 交 的 记录 后 ， 
就 会 直接 转 到 记录 显示 页 。 所 以 提交 过 后 的 记录 显示 页 如 图 14.26 所 示 。 可 以 看 出 , 已 经 显示 出 了 所 添 
加 的 记录 ， 说 明 添加 记录 及 显示 记录 均 执 行 正常 。 

(3) 这 时 就 可 以 对 记录 1 进行 修改 了 。 例 如 ， 记 错 了 门牌 号 ， 把 原本 26 号 写成 了 28 号 ， 那 么 现 
在 把 门牌 号 改过 来 。 单 击 记录 后 面 的 “ 改 ” 链 接 ， 将 执行 14-25.php。 其 结果 如 图 14.27 所 示 。 
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图 14.26 已 经 存在 记录 的 记录 显示 页 执行 结果 图 14.27 记录 修改 页 执行 结果 


(4) 从 图 14.27 可 以 看 出 ， 该 页 正确 显示 出 了 原 有 的 记录 内 容 ， 并 等 待 用 户 输入 新 的 信息 。 这 里 
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把 家 庭 住址 一 项 的 “东区 十 三 街 28 号 ”其 中 的 28 号 改 为 26 号 。 然 后 单 击 “ 确 认 提交 ”按钮 ， 修 改 后 ， 
直接 跳 转 到 了 记录 显示 页 。 结 果 如 图 14.28 所 示 。 

从 图 14.28 的 执行 结果 可 以 看 出 家 庭 住址 一 项 已 经 由 原来 的 “东区 十 三 街 28 号 ” 变 成 了 “东区 十 
三 街 26 号 ”。 说 明 修改 记录 页 也 执行 正常 。 

下 面 测试 记录 显示 页 的 分 页 功能 。 要 想 测 试 此 功能 的 前 提 是 表 中 存放 的 记录 数 要 多 于 在 14-21.php 
中 所 定义 的 $list_num 每 页 显示 数 。 这 里 继续 为 表 中 添加 记录 ， 以 测试 分 页 显示 的 功能 。 

(1) 为 了 方便 查看 分 页 功能 ， 暂 时 把 14-21.php 中 的 $list_num 改 为 “5”。 当 表 中 记录 多 于 5 条 
时 ，14-23.php 的 执行 结果 将 如 图 14.29 所 示 。 
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图 14.28 ”记录 修改 后 记录 显示 页 执行 结果 图 14.29 记录 多 于 一 页 的 执行 结果 


Q) 从 图 14.29 可 以 看 出 ， 这 时 已 经 显示 出 了 指向 下 一 页 的 链接 。 单 击 该 链接 将 显示 后 面 的 两 条 
记录 ， 如 图 14.30 所 示 。 从 图 14.29 及 图 14.30 可 以 发 现 ， 分 页 功能 已 经 得 到 实现 。 

下 面 继 续 来 测试 查找 记录 的 功能 。 

(1) 在 主页 面 上 单 击 “ 查 找 记 录 ” 的 链接 ， 将 会 转 到 查找 记录 页 (执行 14-26.php) ， 执 行 结果 
如 图 14.31 所 示 。 
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1430 ”打开 最 后 一 页 链接 的 结果 图 14.31 查找 记录 前 台 输 入 执行 结果 


(2) 这 里 ， 选 择 姓名 作为 选择 条 件 ， 在 查询 内 容 一 栏 中 输入 “小 李 ”， 然 后 单 击 “ 确 认 提交 ” 按 
钮 ， 将 出 现 如 图 14.32 所 示 的 执行 结果 。 

结果 显示 出 了 姓名 为 “小 李 ” 的 学 生 的 记录 。 说 明 记 录 查 找 功能 正常 运行 。 

至 此 ， 该 系统 基本 上 已 经 测试 完毕 。 
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图 14.32 ERER, ARAR 
不 过 系统 还 有 个 模块 ， 如 学 生 转 学 ， 就 不 用 继续 保留 其 记录 。 就 要 将 相应 的 记录 从 库 表 中 删除 
即 记录 的 删除 的 模块 。 结 合 前 面 所 介绍 的 内 容 ， 这 个 功能 也 是 很 容易 实现 的 。 有 兴趣 的 读者 不 妨 自 己 
动手 把 删除 记录 这 个 功能 添加 上 。 这 样 整个 系统 就 更 加 完善 了 。 


一 次 检阅 。 其 实说 到 底 ， 数 据 库 操作 最 常用 的 也 就 是 浏览 、 添 加 、 修 改 、 删 除 等 。 至 于 用 何 种 方式 ， 
如 何 去 实 现 这 些 功能 ， 就 需要 在 实践 中 不 断 摸 索 了 。 


14.7 本 章 小 结 


数据 库 应 用 是 动态 网 页 技术 最 重要 的 应 用 之 一 。 动 态 网 页 技术 只 有 充分 与 数据 库 结 合 ， 才 能 发 挥 
动态 网 页 技术 的 真正 魅力 。PHP 与 MySQL 是 一 对 黄金 组 合 ， 所 以 学 习 PHP 自然 就 要 学 习 MySQL 数 

这 一 节 为 读者 介绍 了 MySQL 数据 库 的 知识 。 先 从 关系 型 数据 库 入 手 ， 介 绍 了 什么 是 关系 型 数据 
库 及 关系 型 数据 库 所 能 实现 的 功能 。 然 后 ， 又 通过 列表 的 形式 为 读者 介绍 了 PHP 中 常用 的 MySQL 函 
数 。 熟 练 掌握 这 些 函 数 对 编写 基于 数据 库 的 Web 程序 将 起 到 事半功倍 的 效果 。 

这 之 后 为 读者 介绍 了 MySQL 数据 库 的 相关 操作 包括 如 何 连 接 到 MySQL 服务 器 , 显示 可 用 数据 库 ， 
如 何 创建 新 的 数据 库 ， 如 何在 库 中 建 表 及 如 何 删除 数据 库 等 内 容 。 数 据 操作 的 核心 还 是 对 表 的 操作 。 
所 以 接 下 来 就 为 读者 详细 介绍 了 如 何 对 表 执行 INSERT INTO 插入 操作 、SELECT 查询 操作 、UPDATE 
更 新 操作 、DELETE 删除 操作 以 及 ALERT 修改 表 结 构 操 作 等 关键 内 容 。 

其 后 又 介绍 了 高 级 查询 的 使 用 ,包括 WHERE 子 句 、LIMIT 子 句 、ORDER BY 子 句 的 用 法 。 最 后 ， 
通过 一 个 实际 的 例子 ， 把 本 章 所 学 的 内 容 综合 起 来 。 对 学 习 的 内 容 做 了 一 个 很 好 的 实际 应 用 及 总 结 。 

通过 本 章 的 学 习 , 相信 读者 对 于 如 何 使 用 MySQL 与 PHP 结合 创建 Web 应 用 程序 都 会 有 一 个 深刻 
的 认识 。 
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在 本 书 的 第 1 章 曾 就 动态 网 页 与 静态 网 页 的 区 别 为 读者 做 了 介绍 。 其 中 动态 网 页 的 
一 个 显著 将 征 就 在 于 它 能 实现 人 机 互动 。 对 用 户 输入 或 者 选择 的 内 容 能 做 出 相应 的 回 
应 。 这 也 是 动态 网 页 区 别 于 静态 网 页 的 一 个 将 征 。 其 他 动态 技术 是 这 样 ，PHP 当然 也 
不 例外 。 用 PHP 也 能 实现 人 机 互动 。 这 一 节 就 为 读者 介绍 如 何 用 PHP 实现 人 机 互动 。 


人 机 互动 一 般 条 用 两 种 方式 : 一 种 条 用 表单 ， 通 过 表单 不 同 的 选项 ， 或 者 输入 不 同 
的 内 容 ， 返 回 结果 也 不 同 ; 另 一 种 是 条 用 URL 地 址 加 上 各 种 参数 实现 互动 ， 通 过 参数 
的 不 同 ， 返 回 的 内 容 也 有 所 不 同 。 基 于 这 两 种 方式 。 本 章 内 容 主要 也 分 为 两 大 部 分 : 用 
表单 实现 人 机 互动 ; URL 参数 与 PHP。 通 过 本 章 的 学 习 ， 项 望 读者 能 够 就 练 地 使 用 这 
两 种 方式 实现 人 机 互动 。 从 而 能 在 此 基础 上 写 出 丰富 的 Web 应 用 程序 。 
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15.1 用 表单 实现 人 机 互动 


KÉ (FORM) 是 最 常用 的 网 页 组 件 ， 同 时 也 是 交互 式 网 页 ， 实 现 人 机 互动 的 最 常用 的 方式 。 不 
管 是 在 动态 的 ASP、PHP、JSP 文件 中 , 还 是 在 静态 的 HTM, HTML 等 文件 中 都 可 以 发 现 表单 的 身影 。 
这 一 节 就 来 为 读者 介绍 表单 的 使 用 以 及 如 何 使 用 表单 来 实现 人 机 互动 。 


15.1.1 表单 元 素 的 组 成 


RY (FORM) 由 表单 元 素 构成 。 常 用 的 表单 元 素 有 以 下 几 种 : TEXT (文本 框 ) ~ PASSWORD 
(密码 输入 框 ) ~ BUTTON (普通 按钮 》 、RADIO (〈 单 选 按钮 》 、CHECKBOX (HHE) ~ SELECT 
(列表 框 )、TEXTAREA (文本 域 ) 、SUBMIT (提交 按钮 )、RESET CEHJ) ~ HIDDEN (Ka 
藏 域 ) 等 。 下 面 分 别 对 这 些 表单 元 素 做 简单 的 介绍 。 

1. TEXT (文本 输入 框 ) 

文本 框 允许 用 户 输入 字符 、 数 字 或 者 中 文字 符 等 内 容 。 它 常用 的 属性 有 : NAME 属性 、VALUE 
属性 、SIZE 属性 等 。 

文本 输入 框 通常 代码 如 下 : 

<input type="text" name="usemame" value=" 在 这 里 输入 用 户 名 " size="20"> 


其 中 ，NAME 属性 指 该 表单 元 素 的 名 称 ， 一 是 区 别 于 其 他 表单 元 素 的 标志 ， 另 外 设置 该 属性 以 便 
在 程序 中 能 够 调用 该 表单 元 素 。 一 个 表单 元 素 只 有 属于 自己 的 NAME (或 者 ID) 属性 ， 才 能 被 正常 调 
用 。VALUE 属性 指 代 文 本 输入 框 的 默认 值 ， 即 在 用 户 没有 任何 输入 的 情况 下 显示 的 值 。SIZE 属性 指 
该 文本 输入 框 在 浏览 器 中 表现 出 的 长 度 ， 值 越 大 ， 文 本 框 就 越 长 。 在 多 数 浏览 器 中 ， 文 本 框 的 SIZE 
属性 默认 是 20 个 字符 。 

2. PASSWORD (密码 输入 框 ) 

基本 属性 与 TEXT (文本 输入 框 ) 相同 。 不 同 的 是 文本 输入 框 中 ， 可 以 输入 中 文 或 者 其 他 字符 。 
而 一 旦 PASSWORD (密码 输入 框 ) 获得 光标 ， 中 文 输入 法 将 不 再 起 作用 。 密 码 输 入 框 里 面具 能 输入 键 
盘 上 所 标 出 的 符号 ， 而 不 能 输入 中 文 。 另 外 ，TEXT (文本 输入 框 ) 中 所 输入 的 内 容 全 都 是 可 见 的 ， 而 
PASSWORD (密码 输入 框 中 输入 的 所 用 信息 都 将 以 星 号 (*) 显示 。 之 所 以 这 样 就 是 为 了 保护 密码 
不 被 别人 发 现 。 

3. BUTTON (普通 按钮 

按钮 表单 像 下 面 这 样 : 

<input type="button" value=" 点 击 这 里 " onclick="functionname()"> 

该 表单 元 素 ， 也 具有 NAME 属性 与 VALUE 属性 。 属 性 的 意义 与 TEXT (文本 输入 框 ) 大 同 小 异 。 
通常 情况 下 BUTTON (按钮 ) 元 素 还 会 有 ONCLICK ( 单 击 ) 事件 ， 该 事件 通常 指向 JavaScript 函数 。 
这 样 ， 在 按钮 按 下 的 情况 下 就 能 够 执行 相应 的 操作 。 
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4. RADIO ( 单 选 按钮 ) 

单 选 按钮 的 使 用 如 下 所 示 : 

<input type="radio" name="sex" value=" 男 " checked> 

单 选 按钮 通常 是 以 一 组 出 现 ， 该 组 应 具有 相同 的 NAME 属性 和 不 同 的 VALUE 属性 。 在 出 现 的 一 
组 单 选 按 钮 中 ， 只 允许 用 户 选择 一 组 中 的 一 个 ， 所 以 叫 单 选 按钮 。 如 果 某 个 单 选 按 钮 的 初始 状态 为 选 
中 状态 ， 则 该 单 选 按 钮 有 checked 属性 。 

5. CHECKBOX (AWE) 

复 选 框 像 下 面 这 样 的 样式 : 

<input type="checkbox" name="fav" value=" 游 戏 "> 

该 表单 元 素 和 RADIO (〈 单 选 按钮 ) 类 似 ， 通 常 也 是 以 一 组 出 现 ， 该 组 具有 相同 的 NAME 属性 和 
不 同 的 VALUE 属性 。 不 过 与 RADION ( 单 选 按钮 ) 不 同 的 是 ， 在 一 组 中 允许 用 户 进行 多 项 选择 。 所 
选择 的 结果 都 将 被 发 送 到 指定 的 URL 进行 处 理 。 

6. SELECT (列表 框 ) 

列表 框 通常 使 用 以 下 所 示 的 样式 : 

<select name="type" size="1"> 

<option value="1">1</option> 

<option value="2">2</option> 

<option value="3">3</option> 

</select> 

该 表单 元 素 与 前 面 提 到 的 儿 种 有 一 定 的 区 别 。SELECT 元 素 有 NAME 属性 也 有 SIZE 属性 。 但 是 
它 的 每 个 VALUE 属性 却 包括 在 其 下 的 每 个 <option> 项 里 面 ， 即 每 个 <option> 项 对 应 一 个 VALUE， 不 
应 有 重复 。 另外 根据 SIZE 属性 的 不 同 ，SELECT (列表 框 ) 元 素 在 浏览 器 中 会 有 不 同 的 形式 。 当 SIZE 
等 于 1 时 ， 表 现 为 下 拉 菜 单 的 形式 ; 当 SIZE 大 于 1 时 ， 则 表现 为 列表 框 形 式 。 

7. TEXTAREA (XE) 

文本 域 的 使 用 情况 像 下 面 这 样 : 

<textarea name="content" rows="5" cols="40"> 内 容 在 这 里 输入 </textarea> 

TEXTAREA (XER) 又 叫 多 行文 本 框 ， 这 是 相对 于 TEXT 而 言 。 因 为 TEXT 所 输入 的 内 容 只 能 
是 一 行 ， 中 间 不 允许 也 不 会 出 现 回 车 换行 。 而 TEXTAREA (文本 域 ) 则 不 然 ， 里 面 可 以 随意 使 用 回 车 
键 。 表 征 该 元 素 样式 的 属性 有 两 个 分 别 是 rows ( 行 ) 与 cols ( 列 ) 。rows GT) 的 大 小 决定 了 TEXTAREA 
(文本 域 ) 的 高 度 ， 而 cols GD 的 大 小 则 决定 了 TEXTAREA (文本 域 ) 的 宽度 。 另 外 ， 该 表单 元 素 
也 没有 VALUE 属性 。 如 果 要 为 文本 域 设 定 初始 值 ， 把 想 要 设 定 的 内 容 放 在 “<textarea> ”标记 与 
“</textarea>” 标 记 之 间 即 可 。 

8. SUBMIT (提交 按钮 ) 

提交 按钮 使 用 样式 如 下 所 示 : 
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<input type="submit" value=" 提 交 "> 

提交 按钮 的 作用 是 把 表单 输入 结果 发 送 到 指定 的 URL， 当 单 击 事件 发 生 时 ， 结 果 将 会 被 提交 。 该 
表单 元 素 也 有 NAME 属性 与 VALUE 属性 。 作 用 与 上 面 介绍 的 元 素 的 作用 相 类 似 ， 不 再 獒 述 。 

9. RESET〈 重 置 按钮 

重 置 按钮 也 比较 简单 ， 像 下 面 这 样 : 

<input type="reset" value=" 重 新 填写 "> 

RESET《〈 重 置 按钮 ) 。 重 置 按钮 的 作用 是 把 表单 中 所 有 填写 好 的 内 容 恢复 到 原始 值 。 当 表单 中 的 
内 容 需 要 重新 填写 时 单 击 该 按钮 。 同 时 该 元 素 也 具有 NAME 与 VALUE 属性 。 

10. HIDDEN (IR) 

隐藏 域 的 使 用 方法 像 下 面 这 样 : 

<input type="hidden" name="hide" value="hideinfo"> 

HIDDEN 隐藏 域 )。 如 果 有 一 些 信息 不 方便 或 者 不 必要 显示 出 来 ， 使 用 HIDDEN 隐藏 域 〉 是 
比较 方便 的 。 该 元 素 并 不 会 在 浏览 页 面 上 显示 。 由 于 它 不 能 显示 的 特性 ， 所 以 通常 情况 下 都 要 为 
HIDDEN 指定 一 个 VALUE 值 。 并且 该 值 是 不 能 被 用 户 改变 的 。 而 NAME 属性 则 与 上 面 介绍 的 其 他 表 
单元 素 类 似 。 


15.1.2 在 普通 Web 页 中 插入 表单 


在 普通 的 Web 页 中 插入 表单 的 方法 很 简单 。 操 作 步 骤 如 下 所 示 。 
(1) 在 网 页 的 适当 位 置 放置 这 样 的 代码 : 


<form name=f_name action=url method=get or post> 
</form> 


其 中 的 f_name 指 该 整个 表单 域 的 名 称 ; URL 为 处 理 该 表单 结果 的 URL 地 址 。method 则 表明 采用 
何 种 方式 发 送 表单 域 的 数据 。 
(2) 把 所 需要 的 表单 元 素 放 入 到 “<form>” 标 记 与 “</form>” 标 记 之 间 即 可 。 
例如 下 面 的 代码 就 在 一 个 普通 Web 页 中 插入 了 一 组 表单 。 


<html> 

<head> 
<title> 插 入 表单 示例 </title> 
</head> 

<body> 

<center> 

<h3> 插 入 表单 示例 </h3> 
<p> 

<table border=1> 

<form action=15-2.php method=post> 
<tr> 
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<td> 姓 名 : </td> 

<td><input type=text name="name" size="12"></td> 
</tr> 

<tr> 

<td> 性 别 : </td> 

<td> 

<input type=radio name=sex value=" 男 " checked> 男 
<input type=radio name=sex value=" 女 "> 女 
</td> 

</tr> 

<tr> 

<td> 生 日 : </td> 

<td> 

<select name=month> 

<option value=1>1</option> 
<option value=2>2</option> 
<option value=3>3</option> 
<option value=4>4</option> 
<option value=5>5</option> 
<option value=6>6</option> 
<option value=7>7</option> 
<option value=8>8</option> 
<option value=9>9</option> 
<option value=10>10</option> 
<option value=11>11</option> 
<option value=12>12</option> 
</select> 月 

<select name=date> 

<option value=1>1</option> 
<option value=2>2</option> 
<option value=3>3</option> 
<option value=4>4</option> 
<option value=5>5</option> 
<option value=6>6</option> 
<option value=7>7</option> 
<option value=8>8</option> 
<option value=9>9</option> 
<option value=10>10</option> 
<option value=11>11</option> 
<option value=12>12</option> 
<option value=13>13</option> 
<option value=14>14</option> 
<option value=15>15</option> 
<option value=16>16</option> 
<option value=17>17</option> 
<option value=18>18</option> 
<option value=19>19</option> 
<option value=20>20</option> 
<option value=21>21</option> 
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<option value=22>22</option> 

<option value=23>23</option> 

<option value=24>24</option> 

<option value=25>25</option> 

<option value=26>26</option> 

<option value=27>27</option> 

<option value=28>28</option> 

<option value=29>29</option> 

<option value=30>30</option> 

<option value=31>31</option> 

</select> 月 

</td> 

</tr> 

<tr> 

<td> 爱 好 :</td> 

<td> 

<input type=checkbox name=favior[] value=" 旅 游 "> 旅游 
<input type=checkbox name=favior[l value=" 运 动 "> 运动 
<input type=checkbox name=favior[] value=" 看 电影 "> 看 电影 <p> 
<input type=checkbox name=favior[] value=" 游 戏 "> 游戏 
<input type=checkbox name=favior[] value=" 上 网 "> 上 网 
<input type=checkbox name=favior[] value=" 听 音乐 "> 听 音 乐 <p> 
<input type=checkbox name=favior[ value=" 登 山 "> 登山 
<inputtype=checkbox name=favior[] value=" 聊 天 "> 聊天 
</td> 

</tr> 

<tr> 

<td> 其 他 : </td> 

<td> 

<textarea cols=24 rows=5 name=other> 

其 他 信息 在 这 里 输入 : 

</textarea> 

</td> 

</tr> 

<tr> 

<td colspan="2"> 

<center> 

<input type=submit value=" 提 交 "> 

<inputtype=reset value=" 重 置 "> 

</center> 

</td> 

</tr> 

</form> 

</table> 

</center> 

</body> 

</html> 


把 以 上 代码 保存 为 “15-1.php”《 由 于 其 中 并 没有 出 现任 何 PHP 代码 ， 完 全 是 纯 HTML， 所 以 也 
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可 以 保存 为 HTML 文件) 。 在 PHP 执行 环境 下 执行 该 PHP X KARET? > Dia 
件 〈 如 果 保 存 的 是 普通 HTML Sa, Aaaa aua TEETE melt 
开 ) ， 执 行 结果 将 会 如 图 15.1 所 示 。 下 

以 上 代码 中 使 用 了 多 种 表单 元 素 。 通 过 实例 代码 ， 及 其 执 本 一 
行 结 果 ， 可 以 了 解 到 ， 如 何在 普通 Web 页 中 插入 表单 元 素 。 =m MSATA i 
及 如 何 使 用 各 种 表单 元 素 。 WA i 
15.1.3 更改 表单 的 ACTION 属性 到 PHP 程序 二 

RE: 

只 有 了 表单 ， 相 当 于 只 有 了 前 台 ， 如 果 没 有 后 台 的 支撑 ， 一 8g 一 一 

只 有 表单 的 前 台 就 什么 也 做 不 了 。 连接 前 台 与 后 台 之 间 的 纽带 ee 


MERY (FORM) 的 ACTION 属性 。 所 以 ， 要 想 让 表单 起 作 ci 

用 ,就 必须 有 特定 的 后 台 处 理 程序 ; 而 要 想 让 这 后 台 处 理 程序 图 154 插 ^ 表 站 示例 执 行 结果 

为 前 台 表 单 服务 ， 就 必须 为 表单 指定 ACTION 属性 。 表 单 的 ACTION 属性 通常 都 为 一 个 URL 地 址 。 
在 15-1.php 中 ，form 标签 没有 任何 属性 ， 这 里 为 其 指定 ACTION=15-2.php〔 现 在 这 个 文件 并 不 存 

在 ， 在 15.1.5 小 节 将 会 创建 ) 。 修 改 以 后 备用 。 


15.1.4 表单 METHOD 属性 POST 5 GET 区 别 


在 15.1.2 小 节 就 曾 为 读者 介绍 过 ， 表 单 的 METHOD 属性 指 代 表单 数据 的 发 送 方式 。 通常 表单 数 
据 通过 两 种 方式 发 送 到 目标 URL。 一 种 是 POST 方式 ， 另 一 种 是 GET 方式 。 这 两 种 方式 是 有 一 定 区 
别 的 。 

理论 上 两 者 的 区 别 : 用 GET 方法 提交 的 表单 ， 提 交 的 数据 被 附加 到 URL 上 ， 作 为 URL 的 一 部 分 
发 送 到 服务 器 端 ， 这 种 方式 就 类 似 于 采用 URL 方式 实现 互动 〈 后 面 将 后 讲 到 ) ; 而 POST 方式 则 是 将 
表单 中 的 信息 作为 一 个 数据 块 发 送 到 服务 器 端 ， 这 种 方式 不 依赖 于 URL。 

形式 上 两 者 的 区 别 : 在 实际 应 用 时 ， 两 者 的 区 别 也 是 很 明显 的 ， 由 于 GET 方法 提交 的 数据 是 被 附 
加 到 URL 上 发 送 的 ， 所 以 在 地 址 栏 中 将 会 显示 出 用 户 所 输入 的 数据 作为 参数 附加 在 URL 后 面 ; 反之 
由 于 POST 方法 不 依赖 于 URL， 所 以 使 用 POST 方法 传送 数据 时 ， 地 址 栏 只 会 显示 表单 ACTION 所 指 
向 的 URL， 而 不 会 显示 用 户 输入 的 数据 。 

通过 以 上 分 析 可 以 知道 ， 两 种 方式 的 区 别 。 在 何 种 情况 下 使 用 何 种 数据 提交 方式 呢 ? 一 般 情况 下 ， 
如 果 用 户 提交 的 信息 不 含 私密 性 的 东西 ， 如 使 用 者 的 用 户 名 、 密 码 等 信息 时 ， 使 用 GET 方式 提交 表单 
数据 。 反 之 ， 如 果 是 论坛 、 聊 天 室 或 者 其 他 Web 程序 的 登录 页 ， 其 中 包含 有 使 用 者 的 用 户 名 或 者 密码 
内 容 ， 这 时 就 一 定 要 使 用 POST 来 提交 表单 数据 。 


15.1.5 用 PHP 作 后 台 处 理 表单 提交 数据 


在 普通 Web 页 中 插入 了 相应 的 表单 元 素 ， 为 FORM 表单 指定 了 ACTION 属性 ， 并 且 也 使 用 了 相 
应 的 METHOD 提交 方式 。 这 一 小 节 ， 就 来 创建 对 表单 提交 数据 进行 处 理 的 后 台 程 序 。 
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表单 提交 后 ， 一 般 的 处 理 是 对 用 户 提交 的 数据 进行 分 析 ， 要 存 入 文本 文件 ， 或 者 存 入 数据 库 ， 还 
是 对 用 户 提 交 的 信息 与 已 经 存在 的 记录 进行 对 比 ， 以 采取 相应 的 动作 。 不 过 执行 这 些 动 作 的 前 提 是 先 


要 获得 用 户 提交 数据 的 内 容 。 


这 里 要 提 到 php.ini 中 的 GLOBAL 值 。 在 老 版 本 的 PHP 中 ， 默 认 值 是 开启 的 。 表 现在 php.ini 中 就 


是 GLOBAL=ON。 这 样 就 会 存在 一 些 问 题 ， 所 有 


如 用 户 提交 页 中 有 如 下 一 个 表单 。 


<form method=post actionzurl> 

请 输入 用 户 名 : <input type=text name=username> 
<p> 

请 输入 密码 :<input type=password name=pass> 
<p> 

<input type=submit value=" 确 认 提交 "> 

</form> 


户 提交 的 变量 ， 都 可 以 当 作 全 局 变量 直接 被 引用 ， 


如 果 此 时 php.ini 中 的 GLOBAL 值 为 ON， 则 这 些 被 提交 的 变量 ，usernma、pass 在 目标 页 面 中 都 


可 以 这 样 被 直接 引用 ，S$username、S$pass。 


如 果 是 这 样 就 会 存在 一 定 的 安全 隐患 。 所 以 在 后 来 的 PHP 版 本 中 ， 该 GLOBAL 项 都 被 关闭 了 。 
如 果 该 选项 值 为 OFF 的 话 ， 这 些 被 提交 的 变量 就 不 能 被 直接 引用 。 要 引用 这 些 变量 必须 通过 相应 的 


POST 或 者 GET 数组 。 


如 上 面 提交 的 表单 在 php.ini 中 的 GLOBAL 值 为 OFF 时 ， 就 要 这 样 引用 : $_POST[username]、 
$_POST[pass]。 如 果 METHOD 属性 为 GET， 则 要 这 样 引用 : $_GET[username]、$_GET[pass]。 

以 下 讲 到 例子 ， 及 本 书 中 所 有 的 有 关 表单 提交 变量 的 情况 均 采 用 GLOBAL=OFEF 的 值 来 设 定 。 

准备 工作 做 完 ， 就 开始 来 创建 对 15-1.php 的 处 理 页 面 即 15-2.php。 这 里 并 不 对 数据 采取 什么 处 理 ， 


只 是 先 获取 提交 的 内 容 并 显示 出 来 。 


<? 
if(!$_POST[name]) 


echo "没有 相应 的 用 户 名 "; 
echo "<p>"; 
echo "点 <a href=15-1.php> 这 里 </a> 返 回 "; 
exit(); 

} 

else 

t 

?> 

<html> 

<head> 

<title> 提 交 表单 的 处 理 示 例 </title> 

</head> 

<body> 

<center> 

<h3> 提 交 表单 处 理 示 例 </h3> 

<table border=1> 

<tr> 


// 判 断 有 无 数据 被 提交 


/中 止 所 有 PHP 运行 


/如 果 有 数据 提交 ， 则 显示 相应 HTML 
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<td colspan=2> 以 下 为 用 户 提交 内 容 </td> 
<tr> 
<td> 姓 名 : </td> 
<td><? echo $_POST[name]?></td> 
</tr> 
<tr> 
<td> 性 别 : </td> 
<td><? echo $_POST[sex]?></td> 
</tr> 
<tr> 
<td> 生 日 : </td> 
<td><? echo $_POST[month]." 月 ".$_POST[date]." 日 "?></td> 
</tr> 
<tr> 
<td> 爱 好 : </td> 
<td> 
<? 
for($i=0;$i<count($_POSTIfavior]);$i++) 
{ 
echo $ POSTIfaviorji$i); 
echo", "; 
3 
?> 
</td> 
</tr> 
<tr> 
<td> 其 他 : </td> 
<td> 
<? 
$other=htmlspecialchars($_POST['other]); // 去 掉 特 殊 字符 
$other=ereg_replace("\An","<br>",$other); // 转 行 回 车 
S$other=ereg_replace("\r","<br>",$other); /转行 换行 
echo $other; 
?> 
</td> 
</tr> 
<tr> 
<td colspan=2> 
<center><a href=15-1.php> 返 回 </a></center> 
</td> 
</tr> 
</table> 
</center> 
</body> 
</html> 
<? 


} 


?> 
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把 以 上 代码 保存 为 “15-2.php”。 把 该 文件 与 15-1.php 放 入 同一 个 目录 之 下 。 然 后 ， 先 在 PHP 执 
行 环 境 下 运行 15-1.php〈 记 得 在 运行 前 ， 要 把 15-1.php 
中 FORM 的 METHOD 属性 设 为 POST，ACTION 属性 


当 提 本 到 单 的 外 如 示例 - Microsoft Internet Kan 
文件 四 RED SFV Ya IRV PMW F 


设 为 15-2.php) 。 按 要 求 完整 填写 相应 信息 ， 然 后 单 击 下 个 王八 
“确认 提交 ”按钮 。 执 行 结果 将 会 如 图 15.2 所 示 。 ee 
从 图 15.2 TURI, 正确 的 返回 了 用 户 提交 的 各 项 
信息 。 这 是 对 这 些 信息 进行 下 一 步 操作 的 关键 。 SE RR. WE EN WER 
需要 注意 的 就 是 多 选 框 checkbox 的 值 的 获取 。 在 合 pe FAR masan 


名 表单 时 使 用 name[] 这 样 的 形式 。 这 样 在 提交 时 ， 提 交 

的 内 容 就 会 以 name[0]、name[1]、…… 、name[n] 的 形 

式 出 现 。 获 取 时 也 要 使 用 循环 来 遍历 数组 。 图 15.2 提交 表单 处 理 的 示例 执行 结果 
对 于 如 何 获取 提交 表单 数据 , 这 一 节 就 介绍 到 这 里 。 


zi 
Eg [el I [E meret 加 


15.2 URL 参数 与 PHP 


使 用 URL 参数 ， 也 是 与 用 户 实现 互动 的 一 种 重要 方式 。 不 过 该 种 方式 与 使 用 表单 相 比 缺点 也 显 而 
易于 ， 就 是 可 视 化 及 友好 程度 都 要 差 一 些 。 表 单 使 用 各 种 表单 元 素来 供用 户 进行 输入 信息 或 者 选择 某 
些 选项 。 而 URL 则 只 能 提供 超 连接 的 形式 来 供用 户 选择 或 者 使 用 某 些 信息 。 同 时 由 于 URL 的 数据 发 
送 方式 与 表单 提交 的 GET 方式 类 似 ， 所 以 使 用 URL 所 附带 的 各 种 参数 都 会 完全 显示 在 浏览 器 的 地 址 
栏 上 。 所 以 ， 它 在 安全 性 方面 也 存在 局 限 性 。 


15.2.1 在 PHP 的 URL 地 址 上 加 入 参数 


使 用 URL 参数 方式 传递 数据 ， 就 是 在 URL 地 址 后 面 加 上 适当 的 参数 。URL 实体 将 对 这 些 参数 进 
行 处 理 。 简 单 的 使 用 方法 这 像 下 面 这 样 : 

http://127.0.0.1/15-3.php?usemame=JACK&sex= 男 &age=23 

然后 ， 直 接 在 地 址 栏 中 输入 这 些 内 容 即 可 (由 于 还 没有 编写 相应 的 PHP 文件 ， 所 以 现在 执行 还 不 
会 有 任何 如 果 ) 。 

通过 以 上 代码 了 解 到 ,在 URL 地 址 后 面 加 参数 ， 要 在 完整 的 URL 后 加 “?” 符 号 。 然 后 是 参数 名 
称 = 参数 值 ， 如 上 面 的 username=JACK。 多 个 参数 之 间 要 使 用 “&” 符 号 ， 它 表示 参数 与 参数 之 间 的 


15.2.2 用 PHP 处 理 提交 的 参数 


前 面 在 介绍 表单 的 提交 方式 时 曾 提 到 过 : 采用 表单 的 GET 提交 方式 提交 的 数据 被 附加 到 URL 上 ， 
作为 URL 的 一 部 分 发 送 到 服务 器 端 。 这 种 方式 就 类 似 于 采用 URL 方式 实现 互动 。 所 以 对 于 采用 URL 


第 15 章 用 PHP 实现 人 机 交互 "297。 


参数 方式 提交 表单 数据 的 获取 也 采用 $_GET[" 参 数 名 称 "] 的 方式 来 获取 。 

如 上 面 的 : 

http://127.0.0.1/15-3.php?usemame=JACK&sex= 男 &age=23 

调用 时 就 可 以 用 $_GET[usemma]、$_GET[sex]、$_GET[age] 来 获取 。 

下 面 来 实际 编写 一 个 可 以 处 理 用 户 以 URL 加 参数 形式 提交 内 容 的 PHP 页 面 。 具 体内 容 参 考 以 下 
代码 : 


<? 
if(!$_GET[username] ) /| 判断 有 无 数据 被 提交 


echo "没有 相应 的 用 户 名 "; 
echo "<p>"; 
exit(); /中 止 所 有 PHP 运行 


} 

else // 如 果 有 数据 提交 ， 则 显示 相应 HTML 
{ 

?> 

<html> 

<head> 

<title> 提 交 URL 参数 的 处 理 示例 </title> 
</head> 

<body> 

<center> 

<h3> 提 交 URL 参数 处 理 示 例 </h3> 
<table border=1> 

<tr> 

<td colspan=2> 以 下 为 用 户 提交 内 容 </td> 
<tr> 

<td> 姓 名 : </td> 

<td><? echo $_GET[username]?></td> 
</tr> 

<tr> 

<td> 性 别 : </td> 

<td> 

<? 

if($_GET[sex]) 

echo $_GET[sex]; 

else 

echo "没有 相应 的 性 别 "; 

?> 

</td> 

</tr> 

<tr> 

<td> 年 龄 : </td> 

<td><? 

if($_GET[age]) 

echo $_GET[age]; 
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else 
echo "没有 相应 的 年 龄 "; 
?> 

<hd> 
</tr> 
</table> 
</center> 
</body> 
</html> 
<? 

} 

7> 


把 以 上 代码 保存 为 “15-3.php”。 然 后 在 PHP 执行 环境 中 运行 以 上 代码 ， 将 输出 如 图 15.3 所 示 的 
执行 结果 。 

为 什么 会 这 样 ? 因为 上 面 的 代码 使 用 了 有 无 参数 提交 的 判断 。 而 上 面 在 执行 时 并 没有 附加 任何 参 
数 ， 所 以 才 会 出 现 如 图 15.3 所 示 的 执行 结果 。 下 面 带 上 参数 青 运行 一 次 ,在 地 址 栏 中 输入 下 面 的 内 容 。 

http://127.0.0.1/15-3.php?usemame=JACK&sex= 男 &age=23 

然后 的 执行 结果 就 会 如 图 15.4 所 示 。 
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Æa Ps | 
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CE COOU Oie A COO Ec A 
B 15.3 JEX URL 参数 的 处 理 示例 无 参数 ) 图 15.4 提交 URL 参数 的 处 理 示例 (有 参数 ) 


通过 图 15.4 可 以 发 现 ， 在 加 上 相应 的 参数 之 后 ， 程 序 正确 显示 出 了 用 户 所 提交 的 内 容 ， 实 现 了 互 
动 的 目的 。 
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一 节 通 过 一 个 实例 来 向 读者 介绍 如 何 使 用 表单 。 与 前 面 儿 小 节 介绍 的 不 同 ， 这 一 小 节 的 实例 将 
AAA 与 表单 数据 处 理 的 后 台 整 合 在 一 个 文件 之 中 。 把 表单 相关 的 前 台 与 后 台 整 合 起 来 ， 
一 方面 可 以 减少 文件 个 数 ， 另 一 方面 也 便于 管理 ， 而 且 当 文 件 需要 移动 时 ， 只 用 移动 一 个 文件 即 可 。 

该 实例 实现 的 如 下 功能 ， 当 有 用 户 表单 提交 操作 时 ， 把 用 户 所 输入 的 表单 内 容 存放 到 一 个 以 该 用 
户 所 输入 的 用 户 名 为 文件 名 的 一 个 文本 文件 。 即 该 文本 文件 ， 存 储 着 该 用 户 的 相关 信息 。 
具体 内 容 参看 以 下 代码 : 
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Eri 
if(!$_POST[name]) 

{ 

?> 

<html> 

<head> 

<title> 表 单 使 用 实例 </title> 
</head> 

<body> 

<center> 

<h3> 表 单 使 用 实例 </h3> 
<p> 

<table border=1> 


用 PHP 实现 人 机 交互 


// 判 断 有 无 数据 被 提交 
// 如 果 没 有 数据 被 提交 ， 则 显示 提交 表单 内 容 


<form method=post action=<?echo $PATH_INFO?>> 


<tr> 
<td> 姓 名 : </td> 


<td><input type=text name="name" size="12"></td> 


</tr> 
<tr> 
<td> 性 别 :</td> 
<td> 


<input type=radio name=sex value=" 男 " checked> 男 


<input type=radio name=sex value=" 女 "> 女 
</td> 

</tr> 

<tr> 

<td> 生 日 : </td> 

<td> 

<select name=month> 

<option value=1>1</option> 
<option value=2>2</option> 
<option value=3>3</option> 
<option value=4>4</option> 
<option value=5>5</option> 
<option value=6>6</option> 
<option value=7>7</option> 
<option value=8>8</option> 
<option value=9>9</option> 
<option value=10>10</option> 
<option value=11>11</option> 
<option value=12>12</option> 
</select> 月 

<select name=date> 

<option value=1>1</option> 
<option value=2>2</option> 
<option value=3>3</option> 
<option value=4>4</option> 
<option value=5>5</option> 
<option value=6>6</option> 
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<option value=7>7</option> 

<option value=8>8</option> 

<option value=9>9</option> 

<option value=10>10</option> 

<option value=11>11</option> 

<option value=12>12</option> 

<option value=13>13</option> 

<option value=14>14</option> 

<option value=15>15</option> 

<option value=16>16</option> 

<option value=17>17</option> 

<option value=18>18</option> 

<option value=19>19</option> 

<option value=20>20</option> 

<option value=21>21</option> 

<option value=22>22</option> 

<option value=23>23</option> 

<option value=24>24</option> 

<option value=25>25</option> 

<option value=26>26</option> 

<option value=27>27</option> 

<option value=28>28</option> 

<option value=29>29</option> 

<option value=30>30</option> 

<option value=31>31</option> 

</select> 月 

</td> 

</tr> 

<tr> 

<td> 爱 好 :</td> 

<td> 

<input type=checkbox name=favior[] value=" 旅 游 "> 旅游 
<input type=checkbox name=favior[] value=" 运 动 "> 运动 
<input type=checkbox name=favior[] value=" 看 电影 "> 看 电影 <p> 
<input type=checkbox name=favior[] value=" 游 戏 "> 游戏 
<input type=checkbox name=favior[] value=" 上 网 "> 上 网 
<input type=checkbox name=favior[] value=" 听 音乐 "> 听 音 乐 <p> 
<input type=checkbox name=favior[] value=" 登 山 "> 登山 
<input type=checkbox name=favior[ value=" 聊 天 "> 聊天 
</td> 

</tr> 

<tr> 

<td> 其 他 : </td> 

<td> 

<textarea cols=24 rows=5 name=other> 

</textarea> 

</td> 

</tr> 


<tr> 
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<td colspan="2"> 

<center> 

<input type=submit value=" 提 交 "> 

<inputtype=reset value=" 重 置 "> 

</center> 

</td> 

</tr> 

</form> 

</table> 

</center> 

</body> 

</html> 

<? 

$ 

else // 如 果 有 数据 提交 ， 则 执行 相关 操作 

{ 
$name=$_POST[name]; 
$sex=$_POST[sex]; 
$birthday=$_POST[month]."A".$_POST[date]." A"; 
for($i=0;$i<count($_POST[favior]);$i++) 


$f=$f.$_POST[favior][$i]."+"; 


} 

$other=htmlspecialchars($_POST[other]); // 去 掉 特 殊 字符 
$other=ereg_replace("\r\n","<br>",$other); /| 转行 回 车 
$other=ereg_replace("\r","<br>",$other); // 转 行 换行 
$s=$name." ".$sex." ".$birthday.™ ™".$f.™*".$other."\n"; 
$myfile=fopen($name,"w"); // 创 建文 件 
fwrite( $myfile,$s); // 置 入 相应 内 容 
fclose($myfile); // 关 闭 文件 
echo "用 户 输入 内 容 为 :"; 


echo $name."<p>"; 
echo $sex."<p>"; 


echo $birthday."<p>"; 

echo $f."<p>"; 

echo $other; 

echo "<p>"; 

echo "用 户 文件 已 经 创建 完毕 ! "; 


把 以 上 代码 保存 为 “15-4.php”， 然 后 在 PHP 执行 环境 中 运行 该 PHP 文件 。 将 会 出 现 与 15-1.php 
基本 类 似 的 执行 结果 。 因 为 它们 采用 的 前 台 内 容 及 格式 基本 上 是 相同 的 ， 区 别 的 是 在 后 台 。 

在 执行 界面 上 的 表单 中 ， 输 入 相应 内 容 。 这 里 输入 以 下 内 容 〈 当 然 读者 也 可 以 根据 自己 喜好 ， 输 
入 相应 内 容 ) : 

姓名 : JACK、 性 别 : 男 、 生 日 : 11 月 5 日 、 爱 好 :运动 + 看 电影 + 听 音 乐 + 登山 、 其 他 : 该 同志 为 美 籍 华 人 。\n 

现 住 美国 纽约 市 。 


输入 完毕 后 ， 单 击 “ 确 认 提交 ”按钮 ， 将 会 出 现 如 图 15.5 所 示 的 执行 结果 。 
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从 图 15.5 的 执行 结果 可 以 发 现 ， 程 序 正确 显示 出 了 用 户 输 


h 7 „igxi 

入 的 各 项 内 容 ， 并 且 还 提示 用 户 文件 已 经 创建 完毕 。 有 

然后 到 15-4.php 所 在 目录 里 能 够 发 现 名 为 JACK 的 文件 ， 
用 记事 本 打开 它 。 里 面 有 以 下 内 容 : na 

JACK " 男 " 11 月 5 日 "运动 + 看 电影 + 听 音 乐 + 登山 +" 该 同志 为 美 籍 运动 + 看 电影 + 折 音 乐 + 登 山 + 

华人 。<br> 现 住 美国 纽约 市 。 该 同志 为 美 各 华人 ， 

现 住 美国 纽约 市 ， 
说 明 用 户 文件 已 经 被 正确 创建 。 用 户 文件 已 经 创建 宙 | 上 


这 个 表单 使 用 的 实例 就 为 读者 介绍 到 这 里 。 具 体 使 用 中 [SE Ai aaa 
Web 表单 还 有 更 多 的 用 途 ， 如 把 用 户 记 录 存 入 数据 库 、 获 得 用 图 15.5 表单 使 用 实例 处 理 结果 
户 提交 信息 与 库 中 内 容 相 比 较 、 通 过 用 户 提 交 表 单 执行 相关 操 
作 等 。 可 以 说 表单 的 使 用 非常 广泛 。 所 以 只 有 总 练 掌握 了 表单 的 使 用 , 才能 开发 出 高 效 的 人 机 交互 Web 
程序 。 
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实现 人 机 交互 是 动态 网 页 技术 的 重要 特点 之 一 。 本 音 主 要 介绍 用 PHP 实现 人 机 交互 的 两 种 方式 ， 
表单 方式 和 URL 参数 方式 。 其 中 表单 方式 常用 于 论坛 中 的 用 户 注 册 、 用 户 登 录 信 息 录入 等 。 而 URL 
参数 方式 更 多 的 见于 留言 本 中 的 分 页 显示 、 论 坛 中 的 分 主题 显示 、 论 坛 中 不 同 子 论坛 之 间 的 跳 转 等 。 
可 以 说 ， 两 种 方式 都 有 着 广泛 的 应 用 ， 并 且 它 们 各 有 其 优 缺 点 ， 互 为 补充 。 

通过 本 章 对 两 种 实现 人 机 交互 方式 的 学 习 , 及 对 具体 使 用 实例 的 介绍 , 相信 读者 对 于 如 何 通过 PHP 
代码 实现 人 机 交互 ， 会 有 一 个 深刻 的 认识 。 从 而 为 写 出 高 效率 的 Web 应 用 程序 打下 坚实 的 基础 。 

编写 人 机 交互 程序 有 一 个 问题 需要 引起 读者 的 注意 ， 屠 就 是 要 了 解 php.ini 中 GLOBAL 的 状态 ， 
对 于 该 值 不 同 的 状态 采用 不 同 的 变量 获取 形式 。 
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计数 器 在 网 络 上 的 运用 非常 广泛 ,比较 常见 的 应 用 的 是 访客 浏览 量 计数 器 。 在 自己 
的 网 站 里 放置 一 个 访客 浏览 量 计数 器 ， 可 以 帮助 站 长 了 解 站 点 的 访问 情况 。 本 章 就 来 介 
绍 怎样 使 用 PHP 来 开发 计数 器 小 程序 。 其 中 包括 简单 计数 器 、 计 数 器 原理 、 计 数 器 算 
法 的 设计 、 有 具体 代码 实现 计数 器 、 图 形 化 计数 器 、 设 计算 法 、 用 图 片 理 换 文本 、 实 际 代 
码 实现 图 形 化 计数 器 、 计 数 器 的 进一步 完善 和 实现 多 用 户 计数 器 等 内 容 。 
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16.1 简单 计数 器 


计数 器 的 功能 虽然 单一 ， 但 根据 存储 及 表现 方式 的 不 同 也 有 多 种 多 样 。 有 简单 的 文本 计数 器 、 在 
文本 计数 器 基础 上 的 图 形 计数 器 、 以 数据 库 为 基础 的 数据 库 计 数 器 等 。 本 节 先 来 介绍 简单 的 文本 文件 
计数 器 。 


16.1.1 计数 器 的 原理 


计数 器 的 原理 很 简单 ， 就 是 累加 。 如 果 原 始 值 是 “0”， 就 在 0 在 基础 上 累加 1， 结 果 就 是 “1”。 
每 浏览 一 次 就 在 原来 浏览 量 的 基础 上 累加 1 。 

既然 是 简单 的 文本 计数 器 ， 就 采用 文本 文件 作为 载体 。 第 1 次 运行 程序 时 ， 先 判断 有 没有 相应 的 
文本 文件 ， 如 果 没 有 就 创建 文件 ， 并 置 入 “0”。 以 后 程序 运行 时 ， 先 读 出 文本 文件 中 储存 的 数值 ， 把 
原 值 自 增 1 再 把 增加 的 值 显 示 出 来 。 然 后 把 增加 的 值 重 新 写 入 文本 文件 即 可 。 


16.1.2 ”设计 算法 


下 面 设计 计数 器 算法 。 

把 文本 文件 名 定义 给 变量 。 先 判断 文件 是 否 存在 ， 这 里 要 用 到 fileexists() 函 数 。 如 果 不 存在 使 用 读 
写 方式 创建 文件 ， 这 里 要 使 用 open(" 文 件 名 ","a") 函 数 。 置 入 “0”， 这 里 要 使 用 fwrite() 函 数 。 然 后 使 
用 file(" 文 件 名") 函数 读 出 文件 数据 内 容 ， 给 原 值 加 1。 使 用 echo 函数 显示 到 用 户 界面 ， 然 后 再 把 增加 
过 的 值 重 新 写 入 文本 文件 ， 关 闭 文件 结束 程序 。 


16.1.3 ”代码 实现 


下 面具 体 来 实现 16.1.2 节 中 所 要 求 的 功能 。 具 体内 容 参看 以 下 代码 : 


<html> 

<head> 

<title>PHP 文本 计数 器 </title> 

</head> 

<body> 

<? 

$c_file="counter.txt"; /文件 名 赋值 给 变量 

if(!file_exists($c file)) // 如 果 文 件 不 存在 的 操作 

{ 
$myfile=fopen($c_file,"w"); // 创 建文 件 
fwrite($myfile,"0"); IBA “0” 
fclose($myfile); /| 关闭 文件 


} 
$t_num=file($c_file); // 把 文件 内 容 读 入 变量 
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$t_num[O]++; /文件 内 容 自 增 1 
echo "欢迎 ! 您 是 本 站 第 ".$t_num[0]." 位 访客 ! "; // 显 示 文 件 内 容 
$myfile=fopen($c _file,"w"); /打开 文件 
fwrite($myfile,$t_num[0]); // 写 入 新 内 容 
fclose($myfile); 1/ 关闭 文件 

?> 

</body> 

</html> 


保存 以 上 代码 为 “16-1.php”， 然 后 在 PHP 运行 环境 中 执行 以 上 PHP 文件 ， 第 1 次 ii 
果 将 如 图 16.1 所 示 。 

同时 打开 程序 运行 的 文件 夹 ， 会 发 现 多 了 一 个 叫 “counter.txt” 的 文件 。 说 明 程序 正常 运行 。 刷 新 
该 页 面 ， 相 当 于 程序 重新 加 载 一 次 ， 执 行 结果 如 图 16.2 所 示 。 
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图 16.1 文本 文件 计数 器 第 1 次 运行 结果 图 16.2 文本 文件 计数 器 第 2 次 运行 结果 
说 明 程 序 已 经 正常 运行 ， 并 已 经 能 实现 累加 ， 经 得 起 多 次 考验 。 
这 一 节 简 单 文 本 计数 器 就 介绍 到 这 里 。16.2 节 将 介绍 图 形 化 计数 器 。 


I Fr 


16.2 ”图形 化 计数 器 


文本 计数 器 虽然 简单 易 行 ， 但 是 美观 上 就 要 欠缺 一 点 ， 如 果 采 用 图 形 的 方式 来 表达 计数 器 内 容 ， 
就 既 能 实现 计数 功能 ， 又 让 人 印象 深刻 。 本 节 就 来 讲解 在 PHP 中 怎样 在 文本 计数 器 的 基础 上 实现 “图 
形 化 ”的 计数 器 。 


16.2.1 设计 算法 


既然 图 形 计 数 器 是 在 文本 计数 器 的 基础 上 建立 起 来 的 。 所 以 它们 的 算法 是 完全 相同 的 ， 都 是 简单 
的 累加 。 不 同 的 是 文本 计数 器 只 是 把 文本 内 容 简单 的 表现 给 用 户 ， 而 图 形 计数 器 则 是 采用 图 片 的 方式 
来 表达 文本 的 内 容 而 已 。 


16.2.2 用 图 片 替 代 文 本 


在 讲解 本 小 节 实 现 图 形 化 计数 器 之 前 ， 请 先 准备 内 容 为 0~9 的 10 张 小 图 片 , 文件 名 要 与 内 容 一 至 
分 别 为 0.gif、1.gif、…… 、8.gif、9.gif。 

要 实现 图 片 蔡 代 文本 ， 一 位 数 是 不 会 出 现任 何 问题 。 但 是 超过 一 位 就 有 麻烦 了 ， 不 能 准备 11~99 
的 图 片 ， 所 以 要 把 文本 逐个 分 开 ， 再 分 别 用 相应 的 图 片 来 蔡 换 。 这 样 的 话 ，file0) 函 数 就 不 能 满足 需要 
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了 ， 因 为 它 是 把 文件 按 行 读 入 数组 的 ， 所 以 这 里 要 采用 getcO 这 个 函数 ， 因 为 这 个 函数 是 按 字 符 来 读 取 


文件 内 容 的 。 


16.2.3 ”代码 实现 


这 一 小 节 ， 来 具体 讲解 一 下 怎么 用 


个 函数 的 区 别 。 


<html> 
<head> 
<title>PHP 图 形 化 计数 器 </title> 


$c_file="counter.txt"; 
if(!file_exists ($c _file)) 


$myfile=fopen($c_file,"w"); 
fwrite($myfile,"0"); 
fclose($myfile); 


} 

$t_num=file($c_file); 
$t_num[O]++; 
$myfile=fopen($c_file,"w"); 
fwrite($myfile, $t_num[0]); 
fclose($myfile); 

echo "欢迎 ! 您 是 本 站 第 "; 
$myfile=fopen($c_file,"r"); 
while(!feof($myfile)) 


$num=fgetc($myfile); 
if($num) 
{ 


} 


} 
fclose($myfile); 
echo "位 访客 ! "; 
?> 

</body> 

</html> 


echo "<img src=images\\".$num.".gif>"; 


代码 来 实现 图 形 化 计数 器 ， 同 时 也 来 对 比 一 下 file() 与 gete0 两 


// 文 件 名 赋值 给 变量 
// 如 果 文 件 不 存在 的 操作 


// 创 建文 件 
// 置 入 “0” 
IRAS 


// 把 文件 内 容 读 入 变量 
// 原 始 数 据 自 增 1 

// 写 入 方式 打开 文件 
// 写 入 新 数值 

1/ 关闭 文件 

// 显 示 内 容 头 部 

// 以 只 读 方式 打开 文件 
// 循 环 读 出 文件 内 容 


// 当 前 指针 处 字符 赋值 给 变量 
// 如 果 数 值 存在 执行 操作 


// 显 示 相 应 图 片 


/关闭 文件 
/显示 内 容 尾部 


保存 以 上 代码 为 “16-2.php”， 在 PHP 运行 环境 下 执行 这 个 PHP 文件 ， 执 行 结果 如 图 16.3 所 示 。 
说 明 该 计数 器 程序 在 1 位 数 的 情况 下 还 是 能 够 正常 运行 ， 也 是 能 经 得 起 考验 的 。 下 面 持续 刷新 ， 


直到 该 计数 器 达到 9 以 上 ， 执 行 结果 如 图 16.4 所 示 。 


执行 结果 表明 ， 即 使 是 在 游览 量 为 两 位 的 情况 下 ， 该 计数 器 程序 依然 是 经 得 起 考验 的 。 
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通过 这 一 小 节 的 介绍 ， 一 个 既 简 单 ， 又 美观 的 图 形 化 计数 器 已 经 完成 了 。 还 可 以 去 掉 代 码 中 的 
HTML 部 分 ， 只 保留 PHP 代码 ， 这 样 ， 就 可 以 在 其 他 PHP 页 面 中 引用 这 个 文件 了 。 
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图 16.3 图 形 化 计数 器 执行 结果 图 16.4 图 形 化 计数 器 在 浏览 量 超过 两 位 时 的 执行 结果 
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16.3 添加 “防止 恶意 刷新 ”功能 


虽然 现在 已 经 实现 了 计数 器 的 功能 ， 但 是 有 一 点 不 太 完美 的 是 每 当 用 户 刷新 一 下 就 会 使 计数 器 运 
行 一 次 。 这 样 获得 的 情况 往往 不 太 准 确 ， 因 为 可 能 有 别有用心 的 人 不 停 地 刷新 ， 以 达到 计数 器 疯狂 增 
加 的 目的 。 怎 么 样 避免 这 种 状况 的 发 生 呢 ? 这 里 就 要 用 到 功能 强大 的 Cookie 了 。 这 一 小 节 来 讲解 怎样 
通过 Cookie 来 完善 图 形 化 计数 器 。 


16.3.1 设计 算法 


防 刷新 功能 的 算法 是 这 样 ， 先 判断 有 没有 Cookie， 如 果 没 用 Cookie 就 启动 一 次 计数 器 并 且 写 入 当 
天 系统 日 期 到 Cookie 数据 。 当 用 户 刷新 或 者 第 二 次 浏览 时 ， 就 判断 Cookie 的 日 期 是 否 与 系统 日 期 一 
致 ， 如 果 两 者 一 致 则 只 读 出 原始 数据 ， 并 不 执行 自 增 这 一 步 。 这 样 不 论 用 户 如 何 刷新 ， 计 数 器 就 只 能 
够 显示 ， 而 不 能 增加 了 。 


16.3.2 ”代码 实现 
这 一 小 节 ， 将 通过 具体 的 代码 来 实现 增强 版 的 计数 器 ， 通 过 此 例 也 能 加 深 读者 对 Cookie 的 认识 。 


由 于 setcookie 在 使 用 之 前 不 能 有 任何 的 输出 操作 ， 所 以 本 小 节 的 代码 要 对 上 节 的 图 形 化 计数 器 代码 做 
较 大 改动 。 


F 
$c_file="counter.txt"; /文件 名 赋值 给 变量 
if(ifile evists($c file)) // 如 果 文 件 不 存在 的 操作 
$myfile=fopen($c_file,"w"); // 创 建文 件 
fwrite($myfile,"0"); IBA “0” 
fclose($myfile); // 关 闭 文件 
} 
S$t_num=file($c_file); // 把 文件 内 容 读 入 变量 
if($_COOKIE["date"]!="date(Y 年 m 月 d 日 )") /| 判断 COOKIE 内 容 与 当前 日 期 是 否 一 致 


{ 
$t_num[0]++; // 原 始 数据 自 增 1 
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$myfile=fopen($c _file,"w"); // 写 入 方式 打开 文件 
fwrite($myfile, $t_num[0]); // 写 入 新 数值 
fclose($myfile); /关闭 文件 


setcookie("date","date(Y 年 m 月 d 日 )",time()+60*60*24); // 重 新 将 当前 日 期 写 入 COOKIE 并 设 定 Cookie 的 有 效 
期 为 24 小 时 


} 

?> 

<html> 

<head> 

<title>PHP 图 形 化 计数 器 </title> 

</head> 

<body> 

<? 

echo "欢迎 ! 您 是 本 站 第 "; // 显 示 内 容 头 部 

$myfile=fopen($c_file,"r"); /以 只 读 方式 打开 文件 

while(!feof($myfile)) // 循 环 读 出 文件 内 容 
$num=fgetc($myfile); 1/ 当前 指针 处 字符 赋值 给 变量 
if($num) // 如 果 数 值 存在 执行 操作 
1 

echo "<img src=images\\".$num.".gif>"; /显示 相应 图 片 

} 

} 

fclose($myfile); /关闭 文件 

echo "位 访客 ! "; /显示 内 容 尾 部 

?> 

</body> 

</html> 


保存 以 上 代码 为 “16-3.php”， 在 PHP 运行 环境 中 执行 以 上 代码 。 会 发 现 虽然 第 1 次 能 正确 显示 ， 
但 当 刷 新 页 面 的 时 候 ， 显 示 的 还 是 原来 的 值 。 因 为 第 2 次 执行 时 Cookie 中 的 值 与 当前 日 期 一 致 ， 程 序 
并 不 执行 自 增 操作 ， 所 以 显示 的 还 是 原始 值 。 自 此 该 增强 型 的 防 恶意 刷新 计数 器 完成 。 


16.4 多 用 户 计数 器 


在 网 上 经 常 能 找到 面向 多 用 户 的 计数 器 。 任 何人 都 可 以 注册 一 个 用 户 名 ， 然 后 系统 给 出 一 段 
SCRIPT 代码 ， 只 要 把 代码 贴 到 自己 的 页 面 上 就 可 以 实现 计数 器 功能 。 那么 怎样 才能 实现 多 用 户 的 计数 
器 呢 ? 这 一 节 就 来 介绍 如 何在 PHP 环境 中 编写 多 用 户 计 数 器 。 


1641 多 用 户 的 原理 


要 想 实现 多 用 户 计 数 器 ， 就 要 有 多 个 记录 ， 并 且 各 个 记录 之 间 要 互 不 影响 。 访 问 其 中 一 个 用 户 的 
记录 ， 只 在 此 用 户 的 原 有 记录 上 自 增 ， 然 后 重新 保存 在 该 用 户 记 录 里 即 可 。 这 样 就 可 以 实现 多 用 户 计 
数 器 了 。 
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16.4.2 ”实现 方法 


通常 有 两 种 方法 可 以 实现 多 用 户 计数 器 。 实 际 上 也 就 是 两 种 存储 机 制 的 问题 。 大 致 可 以 有 如 下 两 
种 方法 : 

方法 1。 像 前 几 节 介 绍 的 计数 器 一 样 ， 采 用 文本 文件 作为 存储 载体 。 每 个 用 户 记录 对 应 一 个 文本 文 
件 。 第 1 次 访问 时 先 判断 该 用 户 的 文件 是 否 存在 ， 如 果 不 存在 就 创建 文件 并 写 入 “0”。 如 果 文 件 存在 
就 读 出 原 值 并 自 增 “1”。 显 示 新 值 ， 把 自 增 后 的 值 写 入 用 户 文件 即 可 。 

方法 2。 采 用 数据 库 作 为 存储 载体 。 每 个 用 户 对 应 表 里 的 一 条 记录 。 记 录 内 容 为 相应 的 用 户 及 访问 
Eo 第 1 次 访问 时 先 判断 表 中 有 无 该 用 户 的 记录 ， 如 果 没 有 就 写 入 记录 并 初始 化 访问 量 为 “0”。 如 果 
记录 存在 就 读 出 记录 中 访问 量 的 值 并 自 增 “1”。 显 示 出 新 值 ， 再 把 自 增 后 的 值 写 入 表 中 用 户 记录 。 

关于 方法 1， 与 前 面 介 绍 的 例子 差不多 ， 只 是 多 了 一 个 文件 名 的 判断 ， 这 里 不 再 多 介绍 ， 有 兴趣 的 
读者 可 以 自己 研究 。 这 里 重点 介绍 方法 2 的 实现 。 


16.4.3 ”代码 实现 


这 一 节 ， 将 通过 具体 的 代码 来 介绍 数据 库 版 的 面向 多 用 户 计数 器 。 通 过 此 例 也 能 加 深 读 者 对 数据 
库 的 操作 。 由 于 要 用 到 数据 库 、 表 ， 所 以 要 先 在 库 里 创建 表 counter。 表 应 包含 有 字段 id、usemame、 
count 等 内 容 。 


第 1 步 ， 运 行 以 下 代码 创建 mysql K: 


<? 

$myconn=mysql_connect("localhost","root",”™"); /| 连接 到 服务 器 

mysql_select_ db(test,$myconn); /连接 到 test Æ 

$query="create table counter (id int(5) not null auto_increment primary key,username varchar(20) not null,count 
int(5) not null)"; /创建 counter 表 语 句 

mysql_query($query); /执行 语句 

mysql_close($myconn); /关闭 对 数据 库 的 连接 

echo "你 已 经 成 功 创建 数据 表 "; // 创 建成 功 提示 

?> 


保存 以 上 代码 为 “16-4.php”。 先 打开 MySQL 服务 ， 然 后 在 PHP 运行 环境 下 执行 以 上 代码 。 如 果 
成 功 就 会 提示 创建 数据 表 成 功 提示 。 

第 2 步 ， 以 下 代码 为 多 用 户 计数 器 的 核心 文件 。 

document.write("<? 


if($_GET["username"]) 


$username=$_GET["username"]; 


$myconn=mysql_connect("Iocalhost","root",""); // 连 接 到 服务 器 
mysql_select_dbl(test, $myconn); // 连 接 到 test 库 
$sqlstr="select * from counter where usermame='$usermame'"; // 查 询 用 户 名 语句 


$result=mysql_query($sqlstr) or die(mysql_error()); /执行 查询 语句 
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$num=mysql_num_rows($result); // 查 询 结果 保存 到 变量 
if($num==0) // 如 果 结果 为 0 执行 操作 
{ 

$sqlstr="insert into counter (username) values ("$username')"; /| 插入 记录 语句 
mysql_query($sqlstr) or die(mysql_error()); /执行 语句 
} 
$sqlstr="select count from counter where usemame-'$usemame"; // 重 新 查询 
$result=mysql_query($sqlstr) or die(mysql_error()); // 执 行 查询 语句 
$count=mysql_fetch_array($result); // 结 果 保 存 到 变量 
$count[0]++; // 自 增 1 
echo $count[0]; /显示 新 结果 
$sqlstr="update counter set count=count+1 where usemame='$usemame"; /更 新 数据 表 
$result=mysql_query($sqlstr) or die(mysql_error()); /执行 更 新 语句 
mysql_close($myconn); 1/ 关闭 数据 库 连接 
} 
else echo "用 户 名 不 能 为 空 "; 
?> 
位 访问 者 "); 


保存 以 上 代码 为 “16-5.php”。 然 后 在 需要 调用 的 Web 页 中 插入 以 下 代码 : 

<script language="javascript" src="http://127.0.0.1/16-5.php?username=test"> 

</script> 

其 中 的 src 放置 counter.php 文件 的 绝对 路 径 ，username 为 用 户 名 。 然 后 再 浏览 用 户 的 普通 Web 页 
面 就 可 以 顺利 执行 ， 运 行 效果 如 图 16.5 所 示 。 

这 里 可 以 更 改 username 以 验证 是 否 支 持 多 用 户 。 更 改 用 户 名 为 test2， 可 以 发 现 运行 效果 与 用 户 名 
为 test 类 似 。 只 不 过 又 从 1 开始 计数 。 
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图 16.6 多 用 户 计数 器 在 更 改 用 户 后 的 执行 结果 
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图 16.5 多 用 户 计数 器 测试 结果 
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JH PHPMYADMIN 打开 数据 库 , 查 看 TEST 库 中 的 counter K, 发 现 已 经 有 了 两 条 记录 ,一 条 为 test， 
另 一 条 为 test2。 说 明 多 用 户 计数 器 已 经 完成 了 。 


16.5 本 章 小 结 


本 章 为 读者 介绍 了 能 经 常用 到 的 PHP 计数 器 。 详 细 说 明了 在 PHP 编程 环境 下 ， 怎 样 开发 计数 器 。 
通过 本 章 学 习 ， 读 者 不 仅 学 到 了 计数 器 的 算法 ， 同 时 也 复习 了 PHP 对 文件 的 操作 、PHP 中 Cookie 的 
使 用 、PHP 对 MySQL 数据 库 的 操作 等 内 容 。 计 数 器 的 功能 虽然 简单 ， 但 要 做 一 个 完善 的 计数 器 ， 就 
要 结合 多 方面 知识 才能 实现 的 。 


网 上 投票 程序 


投票 程序 的 原理 
投票 项 管理 
显示 投票 项 
防止 重复 投票 
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投票 程序 在 网 上 也 有 着 广泛 的 应 用 。 如 对 基 一 个 问题 的 问卷 调查 ， 或 者 网 站 站 长 对 
网 站 满意 度 的 调查 等 。 本 章 将 向 读者 介绍 如 何 使 用 PHP 来 制作 一 个 投票 系统 。 通 常 的 
投票 系统 按 数据 存储 机 制 的 不 同 可 分 为 文本 类 和 数据 库 类 ， 本章 将 重点 介绍 后 者 。 本章 
内 容 包括 网 上 投票 程序 的 原理 、 数 据 库 表 的 设计 、 管 理 页 面 的 编写 、 用 户 提 交 内 容 的 处 
理 等 。 通 过 对 本 章 的 学 习 ， 读 者 将 能 够 轻松 地 使 用 PHP 编写 出 投票 程序 。 
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17.1 投票 程序 的 原理 


投票 程序 的 实现 方法 其 实 并 不 复杂 ， 通 常 采用 这 样 的 算法 : 事先 建立 好 投票 项 ， 当 用 户 通过 前 台 
对 某 一 项 (适用 于 单项 选择 ) 或 者 几 项 适用 于 多 项 选择 ) 投票 项 进行 选择 并 提交 时 ， 后 台 处 理 就 在 
相应 的 记录 上 增加 1。 显示 投票 内 容 时 一 并 显示 相应 投票 项 的 记录 情况 。 这 样 就 可 以 实现 一 个 投票 程 
序 了 。 

当然 单 选项 的 计 票 方式 就 很 简单 ， 每 投 一 票 计数 一 次 即 可 。 不 过 这 里 涉及 一 个 问题 ， 那 就 是 关于 
多 选项 如 何 计 票 的 问题 。 可 以 把 一 次 多 选 的 所 有 选择 项 当 作 一 次 计数 ， 如 一 次 多 选 了 三 项 ， 就 当 作 一 
次 计数 。 也 可 以 把 一 次 多 选 的 几 项 当 作 几 次 计数 ， 如 一 次 多 选 选 了 三 项 内 容 ， 就 当 作 三 次 计数 。 本 章 
的 实例 将 采用 后 一 种 方式 来 计 票 。 


17.2 本 实例 的 特点 


本 章 将 向 读者 介绍 一 个 简单 的 网 上 投票 系统 。 本 系统 大 致 有 如 下 几 个 特点 。 

用 户 可 以 无 限 增加 投票 项 目 ， 每 个 项 目 可 以 设 定 为 单 选 或 者 多 选 。 

每 个 项 目 也 可 以 自 定义 投票 项 数目 、 投 票 项 内 容 。 

投票 结果 采用 图 片 数字 百分比 两 种 方式 显示 ， 用 户 也 可 以 自 定义 每 个 投票 项 的 图 片 颜色 。 
投票 显示 采用 JS 方式 调用 ， 所 以 ， 可 以 在 普通 Web 页 里 插入 相应 的 JS 代码 来 显示 。 

可 以 设置 是 否 用 Cookie 保存 投票 人 的 IP 记录 ， 同 时 设置 是 否 允 许 同 一 IP 地 址 的 多 次 投票 ， 
这 样 可 以 防止 重复 投票 。 

以 上 就 是 本 章 所 要 介绍 的 投票 系统 的 主要 特点 ，17.3 节 将 为 读者 介绍 数据 表 的 结构 及 各 项 内 容 。 


OOOODO 


17.3 投票 实例 数据 表 的 设计 


数据 表 的 设计 是 一 个 数据 库 应 用 程序 的 最 为 重要 的 一 个 环节 。 因 为 数据 表 设 计 的 适当 与 否 直接 关 
系 着 程序 的 运行 效率 。 良 好 的 、 设 计 合理 的 数据 表 将 对 程序 的 运行 起 到 事半功倍 的 效果 。 相 反 ， 如 果 
数据 表 设 计 得 混乱 那么 程序 运行 起 来 ， 要 完成 同一 个 操作 就 需要 执行 更 多 的 指令 。 这 样 程序 运行 就 会 
受到 相当 大 的 影响 。 

为 了 简化 操作 ， 使 程序 更 容易 理解 ， 本 章 的 投票 程序 实例 的 数据 表 采 用 两 个 表 来 设计 。 采 用 两 个 
表 来 包含 整个 系统 的 全 部 信息 势必 比 采 用 一 个 表 设 计 要 提高 程序 的 复杂 程度 , 但 这 样 会 使 得 思路 清晰 ， 
使 读者 特别 是 初学 数据 库 技术 的 读者 容易 理解 。 

本 章 的 投票 程序 实例 共有 两 个 表 ， 详 见 以 下 内 容 。 

投票 项 记录 表 ， 表 名 VOTE， 共 有 4 个 字段 ， 每 个 字段 及 其 含义 见 表 17.1。 
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表 17.1 投票 项 记录 表 VOTE 字段 列表 


字 段 名 其 t 
表 的 主 关键 字 ， 有 
i 
ID 记录 投票 项 的 ID 号 自动 增加 的 特性 


V_NAME 投票 项 的 名 称 ， 实 际 上 是 一 个 投票 项 的 标题 无 
记录 投票 项 的 结果 。 该 字段 存放 投票 的 总 数 。 如 果 投 
票 项 为 单 选 项 ， 则 每 有 一 次 投票 ， 该 值 增加 1。 如 果 投 
票 项 为 多 选项 ， 则 每 有 一 次 投票 ， 该 值 增 加 投票 选择 
项 的 项 目 数 

记录 投票 项 的 类 型 。 该 字段 保存 投票 类 型 的 标记 。 如 
果 该 值 为 0， 表 示 为 单 选项 ， 如 果 该 值 为 1， 表 示 为 多 
选项 。 在 显示 投票 时 将 调用 该 值 以 确定 显示 的 表单 元 
素 是 radio 还 是 checkbox。 然 后 就 在 处 理 投票 结果 时 调 
用 该 值 ， 如 果 值 是 单 选项 ， 则 采用 一 次 计数 ， 如 果 是 
多 选项 则 采用 多 次 计数 


V NUM Æ 


V_TYPE 


以 上 是 记录 投票 项 的 表 ， 下 面 是 记录 每 一 个 投票 项 的 选择 支 表 。 
投票 项 选择 支 表 ， 表 名 RECORD， 共 有 5 个 字段 ， 每 个 字段 及 含义 见 表 17.2。 
表 17.2 投票 项 选择 支 表 RECORD 字段 列表 
AI 其 他 
记录 投票 项 的 ID 号 ， 以 此 对 每 个 投票 选择 支 进行 区 别 | 表 的 主 关键 字 ， 有 


自动 增加 的 特性 
记录 该 投票 支 所 对 应 的 VOTE 中 投票 项 的 ID， 以 表明 
该 选择 支 是 属于 哪 一 个 投票 项 的 


记录 该 选择 支 的 被 选 结果 ， 存 放 该 选择 支 被 选择 的 
次 数 
记录 该 选择 支 的 显示 颜色 ， 实 际 是 用 相应 的 小 图 片 来 
显示 


由 于 采用 的 是 两 个 表 设 计 ， 所 以 ，VOTE 表 中 存放 投票 项 的 总 情况 ， 具 体 每 一 项 内 容 存 放 到 
RECORD 表 中 。 这 样 的 表 结 构 虽 然 比 采用 单一 表 设 计 的 表 稍 显 复 杂 ， 但 实际 运行 起 来 ， 却 会 比 采用 单 
表 的 设计 效率 更 高 。 


17.4 代码 实现 


本 节 就 开始 通过 具体 的 代码 来 一 步 一 步 完 成 这 个 投票 程序 。 该 投票 程序 共有 以 下 几 个 模块 组 成 : 
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新 建 投票 项 、 显 示 所 有 投票 项 、 单 一 投票 项 的 JS 显示 、 处 理 用 提交 的 内 容 等 。 下 面 ， 就 分 别 介绍 。 
17.4.1 准备 工作 

在 做 这 些 工作 之 前 ， 有 两 项 工作 是 必须 要 事先 完成 的 。 


第 1 步 ， 建 立 一 个 配置 文件 ， 存 放 程序 所 要 调用 的 一 些 重 要 变量 ， 如 主机 名 、 用 户 名 、 用 户 密码 、 
库 名 、 表 名 等 内 容 。 其 内 容 如 下 : 


<? 

$db host-"localhost"; /| 主机 名 
$db_user="root"; IAPR 
$db_pass=""; /密码 
$db_name="test"; /| 操作 库 名 
S$table_vote="vote"; // 表 名 1 
S$table_record="record"; IRB 2 

$re vote-false; /是 否 允 许 重复 投票 
?> 


把 以 上 代码 保存 为 “17-1.php”， 该 文件 将 作为 整个 投票 程序 的 配置 文件 在 多 处 被 调用 ， 所 以 要 首 
先 被 创建 。 

第 2 步 ， 由 于 所 有 的 操作 都 需要 通过 对 相应 的 表 的 操作 来 完成 ， 所 以 必须 事先 要 把 表 创 建 好 。 下 
面 的 代码 给 出 了 创建 表 的 全 过 程 。 


<? 

require "17-1.php"; // 调 用 配置 文件 

和 link=mysql_connect($db_host,$db_user,$db_pass)or die(mysql_error()); // 连 接 主机 
mysql_select_db($db_name,$link); /| 选择 数据 库 


$sql="create table $table_vote( 
id int(5) not null auto_increment primary key, 
v_name varchar(50) not null default ", 
v_num int(5) not null default 0, 
v type int(1) not null default 0 


; /创建 vote 表 的 SQL 语句 
if(mysql_query($sql,$link)) /发 送 SQL 请 求 
echo "投票 表 已 经 创建 成 功 ! <p>"; /如 果 SQL 语句 成 功 执行 ， 则 显示 信息 
else 
echo "创建 表 时 出 现 错误 ， 表 未 被 成 功 创建 。<p>"; 
$sql="create table $table record( 
id int(5) not null auto_increment primary key, 
r id int(5) not null default 0, 
r name varchar(50) not null default", 
r num int(5) not null default 0, 
r color int(1) not null default 0 
从 /| 创建 record 表 的 SQL 语句 
if (mysql_query($sql, $link)) /发 送 SQL 请 求 并 做 判断 
echo "记录 表 已 经 创建 成 功 ! <p>"; // 如 果 SQL 语句 被 成 功 执行 ， 则 显示 创建 成 功 信息 
else // 如 果 创 建 表 失败 ， 则 显示 信息 


echo "创建 记录 表 时 出 错 ， 记 录 表 未 被 成 功 创建 。<p>"; 


?> 
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把 以 上 代码 保存 为 “17-2.php”， 然 后 在 PHP 执 
行 环境 下 执行 该 PHP 文件 ， 执 行 结果 将 会 如 图 17.1 PE 
所 示 。 te 

从 图 17.1 的 执行 结果 的 提示 可 以 看 出 , 相应 的 表 ERREN | 
已 经 被 正确 创建 。 随 着 表 的 创建 完成 ， 编 写 投票 程序 az kamaa A 
的 准备 工作 就 完成 了 。 从 17.4.2 小 节 开 始 就 来 创建 投 图 17.1 创建 数据 表 执行 结果 
票 系统 的 各 个 子 模块 。 


17.4.2 创建 显示 所 有 投票 项 的 页 面 


本 节 来 编写 显示 所 有 投票 项 的 页 面 。 该 页 面 的 作用 是 把 所 有 已 经 存在 的 投票 项 显示 给 管理 者 ， 以 
便于 用 户 对 这 些 投票 项 进行 相应 的 管理 。 
下 面 为 显示 所 有 投票 项 页 面 的 代码 : 


<html> 

<head> 

<title> 投 票 程序 一 一 显示 所 有 投票 项 </title> 
</head> 
<body> 
<center> 
<h1> 投 票 程序 
<p> 

<a href=17-4.php> 添 加 记录 </a> 

<p> 

<? 

require "17-1.php"; 
S$link=mysql_connect($db_host,$db_user,$db_pass)or die(mysql_error()); 


显示 所 有 投票 项 </h1> 


mysql_select_db($db_name,Slink); /连接 主机 选择 数据 库 
$sql="select * from $table vote"; /选择 所 有 投票 项 记录 
$result=mysql_query($sql,$link); /发 送 SQL 请 求 
$rows=mysql_fetch_array($result); // 计 算 总 记录 数 
if($rows==0) // 如 果 没 有 记录 ， 则 显示 内 容 

echo "现在 还 没有 记录 ! "; 
} 
else /| 如果 存 在 记录 ， 则 显示 出 记录 
{ 

echo "<table border='1'>"; 

echo "<tr>"; 

echo "<td width='10%'>"; 

echo "项 "; 

echo "</td>"; 

echo "<td width='80%'>"; 

echo "名 称 "; 

echo "</td>"; 


echo "<td width='10%'>"; 
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echo "&nbsp;"; 
echo "</td>"; 
echo "</tr>"; 
$i=0; 
$sql="select * from $table vote"; /再 次 执行 SQL 请 求 
Sresult=mysql_query($sql,$link); 
while($row=mysql_fetch_array($result)) IBAR 
{ 
$i++; // 循 环 变量 ， 显 示 数 值 
echo "<tr>"; 
echo "<td>"; 
echo "第 ".$i." 条 "; /显示 数值 
echo "</td>"; 
echo "<td>"; 
echo "<a href=17-6.php?id=".$row[id].">".$row[v_name]."</a>"; 
echo "</td>"; 
echo "<td>"; 
echo "<a href=17-5.php?id=".$row[id]."> 删 除 </a>"; 
echo "</td>"; 
echo "</tr>"; 


echo "</table>"; 


} 


?> 
</center> 
</body> 
</html> 


把 以 上 代码 保存 为 “17-3.php”， 以 备 后 用 。 
1743 创建 添加 投票 记录 页 面 


本 节 来 创建 管理 者 添加 新 的 投票 项 的 页 面 。 当 用 户 执行 该 页 面 后 ， 该 添加 操作 分 3 步 进 行 。 第 1 
步 ， 用 户 输入 要 创建 的 投票 项 的 名 称 ， 选 择 投票 子 项 的 条 数 ， 并 选择 该 投票 项 是 多 选 还 是 单 选 。 第 2 
步 ， 用 户 分 别 输入 每 一 条 投票 子 项 的 内 容 ， 并 选择 每 一 条 子 项 对 应 的 颜色 。 第 3 步 单 击 “ 确 定 ” 按 钮 ， 
完成 所 有 的 创建 工作 。 

由 于 该 文件 整合 了 添加 投票 记录 的 3 步 操作 ， 所 以 要 对 每 一 步 要 进行 什么 内 容 的 操作 进行 判断 。 
这 样 把 所 有 操作 整合 起 来 虽然 会 使 代码 比较 长 ， 但 却 减 少 了 文件 的 个 数 ， 更 便于 用 户 对 整个 系统 的 


管理 。 
具体 内 容 请 参看 如 下 代码 : 
<? 
if((!$_POST[v_name]) &&(!$_POST{r][1])) /没有 任何 参数 为 第 1 步 
{ 
?> 


<html> 
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<head> 
<title> 投 票 程序 一 一 增加 投票 项 第 一 步 </title> 
</head> 
<body> 
<script language=javascript> 
function juge(form) 
{ 

if (form.v_name.value =: 


{ 


alert(" 请 输入 投票 项 名 称 ""); 
theForm.v_name.focus(); 
retum (false); 
} 

3 

</script> 

<center> 

<h1> 投 票 程序 一 一 增加 投票 项 第 1 步 </h1> 

<p> 

<h3> 投 票 项 属性 </h3> 

<p> 

<table border=1> 


<form method="post" action=<?_SERVER[PHP_SELF]?> onsubmit="return juge(this)"> 


<tr> 

<td> 输 入 投票 项 内 容 : </td> 

<td><input type=text name=v_name></td> 
</tr> 

<tr> 

<td> 选 择 投票 项 的 类 型 </td> 

<td> 

<input type=radio name=v_type value=0 checked> 单 选 
<input type=radio name=v_type value=1> 多 选 </td> 
</tr> 

<tr> 

<td> 选 择 投票 项 的 项 数 </td> 

<td> 

<select name=v_m size=1> 

<option value=2>2</option> 

<option value=3>3</option> 

<option value=4>4</option> 

<option value=5>5</option> 

<option value=6>6</option> 

<option value=7>7</option> 

<option value=8>8</option> 

<option value=9>9</option> 

<option value=10>10</option> 

</select> 

</tr> 

<tr> 

<td colspan="2"> 
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<center><input type=submit value=" 下 一 步 "></center> 
</td> 
</tr> 
</form> 
</table> 
</center> 
</body> 
</html> 
<? 
3 
else if(!$_POST{r][1]) // 没 有 选择 项 参数 为 第 2 步 
{ 
?> 
<html> 
<head> 
<title> 投 票 程序 一 一 增加 投票 项 第 2 步 </title> 
</head> 
<body> 
<script language=javascript> 
function juge(form) 
{ 
if (form.v_name.value == "") 
{ 
alert(" 请 输入 投票 项 名 称 ""); 
theForm.v_name.focus(); 
retum (false); 
} 
} 
</script> 
<center> 
<h1> 投 票 程序 一 “增加 投票 项 第 二 步 </h1> 
<p> 
<h3> 投 票 项 每 项 选择 项 属性 </h3> 
<p> 
<table border=1> 
<form method="post" action=<?_SERVER[PHP_SELF]?> onsubmit="return juge(this)"> 
<? 
$v_name=$_POST[v_name]; /获取 传 入 变量 
$v_type=$_POST[v_type]; 
$v_m=$_POST[v_m]; 
echo "<tr><td colspan=4><center>".$v_name."</center></td></tr>\n"; 
echo "<input type=hidden name=v_name value=".$v_name.">\n"; 
echo "<input type=hidden name=v_type value=".$v_type.">\n"; 
echo "<input type=hidden name=v_m value=".$v_m.">\n"; 
for($i=1;$i<($v_m+1); $i++) // 循 环 显示 每 个 选择 项 
{ 
echo "<tr>"; 
echo "<td> 选 择 项 ".$i." 内 容 : </td>\n"; 
echo "<td>"; 
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echo "<input type=text name=r[]>"; 
echo "</td>\n"; 
echo "<td>"; 
echo "颜色 "; 
echo "</td>\n"; 
echo "<td>\n"; 
echo "<select size=1 name=c[]>\n"; 
echo "<option value=1> 红 </option>\n"; 
echo "<option value=2> 蓝 </option>\n"; 
echo "<option value=3> 绿 </option>\n"; 
echo "<option value=4> 黄 </option>\n"; 
echo "<option value=5> 紫 </option>\n"; 
echo "</td>\n"; 
echo "</tr>\n"; 

} 

?> 

<tr> 

<td colspan="4"> 

<center> 

<input type=button value=" 上 一 步 " onclick=history.go(-1)> 

<input type=submit value=" 下 一 步 "> 

</center> 

</td> 

</tr> 

</form> 

</table> 

</center> 

</body> 

</html> 

<? 


else // 除 以 上 两 种 情况 之 外 为 第 3 步 


$v_name=$_POST[v_name]; /获取 传 入 变量 
$v_type=$_POST[v_type]; 

$v_m=$_POST[v_m]; 

for($i=! 
{ 


S$r0=$_POSTI[AIS]; 

$c[=$_POST[c][$i]; 
} 
require "17-1.php"; 
S$link=mysql_connect($db_host,$db_user, $db_pass); 


mysql_select_db($db_name, $link); /| 连接 服务 器 选择 库 


$sql="insert into $table vote(v name,v type) values('$v name','$v type')"; 


mysql_query($sql,$link); // 插 入 投票 记录 
$sql="select max(id) from $table_vote"; 
$result=mysql_query($sql,$link); 
$row=mysql_fetch_array($result); 


;$i<$v_m;$i++) /| 循环 读 取 数组 变量 
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for($i=0;$i<$v_m;$i++) /循环 插入 选择 项 记录 

$temp=$r[$i]; 
$temp2=$c[$i]; 
$sql="insert into $table_record(r_id,r_name,r_color) values('$row[0]','$temp','$temp2')"; 
mysql_query($sql, $link); IARR 

?> i 

<html> 

<head> 

<meta http-equiv="refresh" content="2; url=17-3.php"> 

<title> 投 票 程序 一 一 增加 投票 项 第 三 步 </title> 

</head> 

<body> 

投票 项 创建 成 功 ! <p> 

两 秒 后 返回 

</body> 

<? 

} 


?> 


把 以 上 代码 保存 为 “17-4.php”， 以 备 后 用 。 
17.4.4 创建 删除 投票 项 的 页 面 


本 节 创建 删除 投票 项 的 页 面 。 该 文件 首先 要 获取 用 户 提交 的 ID， 然后 从 表 中 选择 出 相应 的 ID,， 并 
进行 删除 操作 。 删 除 投票 的 实质 ， 要 对 两 个 表 进 行 操作 。 一 要 删除 表 vote 中 指定 ID 的 记录 ， 另 一 方 
面 也 要 删除 表 record 中 r_id 等 于 指定 ID 的 记录 ， 也 就 是 删除 投票 项 相应 的 选择 支 。 

下 面 就 来 具体 创建 该 页 面 。 内 容 请 参看 以 下 代码 : 


wi 

if(l$_GET[id]) // 如 果 没 有 指定 删除 1D， 则 显示 信息 
echo "没有 指定 ID! "; 
exit(); 

} 

else // 如 果 指 定 了 删除 ID， 则 执行 操作 

{ 

require "17-1.php"; // 调 用 配置 文件 

$link=mysql_connect($db_host,$db_user,$db_pass)or die(mysql_error()); // 连 接 主机 

mysql_select_db($db_name, $link); // 选 择 数据 库 

$sql="delete from $table vote where id='$_GET[id]"; /删除 指定 投票 项 

if(mysql_query($sql,$link)); // 发 送 SQL 请 求 并 对 结果 进行 判断 
echo "成 功 删 除 投票 项 !"; 

} 

else 
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echo "删除 投票 项 时 出 现 错误 !"; 
} 
echo "<p>"; 
$sql2="delete from $table record where r_ id='$_GET[id]'";// 删 除 指定 选择 项 ， 即 某 个 投票 项 的 所 有 选择 支 
if(mysql_query($sql2,$link)); /发 送 SQL 请 求 并 判断 结果 


echo "成 项 删除 选择 项 ! "; 
} 


else 
echo "删除 选择 项 时 出 现 错误 !"; 


} 

echo "<html>"; 

echo "<head>"; 

echo "<title> 投 票 程序 一 一 删除 投票 项 </title>"; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=17-3.php\">"; 
echo "</head>"; 

echo "<body>"; 

echo "成 功 删除 投票 项 记录 ! "; 

echo "<p>"; 

echo "两 秒 后 返回 "; 

echo "</body>"; 

?> 


将 上 面 的 代码 保存 为 “17-5.php”， 以 备 后 用 。 
17.4.5 创建 显示 投票 项 页 面 


本 节 就 编写 投票 项 的 显示 页 面 。 注 意 本 节 与 17.4.2 节 的 不 同 。17.4.2 节 显 示 所 有 投票 项 ， 即 本 节 显 
示 单 一 投票 项 的 详细 情况 ， 即 每 一 个 投票 项 和 它 所 包括 的 选择 项 。 

这 里 采用 两 种 方式 来 显示 , 一 种 是 采用 通常 的 页 面 方式 显示 , 另 一 种 是 采用 JavaScript 方式 来 显示 。 
为 什么 这 样 呢 ? 因为 通常 网 上 的 普通 空间 并 不 支持 PHP, 而 采用 JavaScript 方式 显示 只 需 提 供用 相应 的 
JS 代码 就 可 以 实现 投票 功能 了 。 而 普通 的 显示 方式 ， 则 是 提供 给 支持 PHP 代码 的 用 户 ， 因 为 这 些 用 户 
完全 可 以 直接 拿 来 使 用 。 

先 来 编写 普通 的 显示 某 一 条 投票 项 的 页 面 。 代 码 如 下 : 

<? 


il$_GET[id]) // 如 果 没 有 指定 1D 号 


echo "没有 指定 ID! "; 


exit(); 
else 
echo "<html>"; 


echo "<head>"; 
echo "<title> 投 票 程序 一 一 显示 投票 项 </title>"; 
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echo "</head>"; 


echo "<body>"; 

echo "<center>"; 

require "17-1.php"; // 调 用 配置 文件 
S$link=mysql_connect($db_host,$db_user,$db_pass)or die(mysql_error()); 
mysql_select_db($db_name, $link); // 选 择 数 据 库 
$sql="select * from $table vote where id='$_GET[id]"; 。 // 显 示 指 定投 票 项 
$result=mysql_query($sql,$link); // 发 送 SQL 请 求 
$row=mysql_fetch_array($result); /| 计算 总 列 数 
$s=$row[v_num]; // 赋 值 给 变量 
echo "<h1>$row[lv_name]</h1>"; // 显 示 投票 项 标题 
echo "<p>"; 


echo "<table border=\"1\" width=60%>"; 

echo "<form action=17-9.php method=post>"; 

echo "<input type=hidden name=id value-".$rowlid).">"; 

echo "<input type=hidden name=v_type value=".$row[v_type].">"; 


echo "<tr>"; 
echo "<td>&nbsp;</td><td> 选 项 </td><td> 被 选择 情况 </td>"; 
echo "</tr>"; 
$sql2="select * from $table record where r_id=$_GETI[id]"; 
$result2=mysql_query($sql2,$link); // 发 送 SQL 请 求 以 显示 选择 项 
while($rows=mysql_fetch_array($result2)) 
{ 
echo "<tr>"; 
echo "<td>"; 
if($rowlv_type]==0) 1/ 如果 选 择 类 型 是 单 选 
{ 
echo "<input type=radio name=r value=". $rows[id].">"; 
} 
else // 如 果 选 择 类 型 是 多 选 
{ 
echo "<input type=checkbox name=r[] value=". $rows[id].">"; 
} 
echo "</td>"; 
echo "<td>".$rows[r_name]."</td>"; 
echo "<td>"; 
if($rows[r_num]==0) // 如 果 被 投票 数 为 0 
$width=0; // 图 片 宽度 为 0 
else 
$width=$rows[r_num]/$s; /图片 宽度 为 得 票数 除 以 总 投票 数 
if($width!=0) // 如 果 被 投票 数 不 为 0 显示 图 片 
{ 
echo "<img src=".$rows[r_color].".bmp width=".($width*200)." height=10>\n"; 
? 
echo $rows[r_num]."".$row[v_num]; /显示 数字 
echo "</td>"; 
echo "</tr>"; 


} 


echo "<tr><td colspan=3><center><input type=submit value=\" 确 认 提 交 \"></center></td></tr>"; 
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echo "</form>"; 
echo "</table>"; 


} 


> 


将 以 上 代码 保存 为 “17-6.php”， 以 备 后 
下 面 再 来 创建 一 个 调用 JS 显示 相应 内 容 的 PHP 文件 。 具 体内 容 参 看 以 下 代码 : 


document.write("<? require '17-1.php'; 
S$link=mysql_connect("$db_host","$db_user","$db_pass"); 
mysql_select_db($db_name,$link); 

$sql="select * from $table vote where id='$_GET[id]"; 
$result=mysql_query($sql,$link); 

$row=mysql_fetch_array ($result); 

$s=$row[v_num]; 

echo "<center>"; 

echo '<h1>'.$row[v_name].'</h1>\n'; 

echo "<p>"; 

echo '<table border=1 width=60%>\n'; 

echo '<form action=17-9.php method=post>\n'; 

echo '<input type=hidden name=id value=". $row[id].'>\n'; 
echo '<input type=hidden name=v_type value='.$row[v_type].'>\n'; 
echo '<tr>'; 

echo '<td>&nbsp;</td><td> 选 项 </td><td> 被 选择 情况 </td>\n'; 
echo '</tr>"; 

$sql2="select * from $table record where r_id=$_GETI[id]"; 
$result2=mysql_query($sql2,$link); 
while($rows=mysql_fetch_array($result2)) 

{ 


echo '<tr>'; 

echo '<td>'; 
if($row[v_type]==0) 
{ 


} 


else 


{ 


} 

echo '</td>\n'; 

echo '<td>'.$rows[r_name].'</td>\n'; 
echo '<td>\n'; 

if($rows[r_num]==0) 

$width=0; 

else 

$width=$rows[r_num]/$s; 
if($width!=0) 

{ 


} 


echo '<input type=radio name=r value=".$rows[id].'>\n'; 


echo '<input type=checkbox name=r[] value=". $rows[id].>\n'; 


echo '<img src='.$rows[r_color].'.bmp width=".($width*200).' height=10>\n'; 


和 
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echo $rows[r_num]./.$row[v_num]; 
echo '</td>\n'; 
echo '</tr>\n'; 


echo '<tr><td colspan=3><center><input type=submit value= 确 认 提交 ></center></td></tr>\n'; 
echo '</form>\n'; 

echo '</table>\n'; 

echo '</center>'; 

?> 

wa 

把 以 上 代码 保存 为 “17-7.php”。 

下 面 是 调用 该 JS 页 (17-7.php) 的 普通 HTML 页 面 : 
<html> 

<head> 

<title> 投 票 程序 一 一 调用 JS 页 </title> 

</head> 

<body> 

<script language=javascript src="http://127.0.0.1/17-7.php?id=1"> 
</script> 

</body> 

</html> 


把 以 上 代码 保存 为 “17-8.php”。 由 于 该 页 面 中 没有 任何 可 执行 的 PHP 代码 ， 所 以 该 页 面 可 以 是 
普通 的 HTML 页 。 通 过 以 上 代码 可 见 ， 要 调用 JS 页 时 要 使 用 

<script language=javascript src="http://127.0.0.1/17-7.php?id=1"> 

</script> 
PÉIR, 其 中 的 sre 为 17-7.php 的 相对 或 者 绝对 路 径 ， 注 意 不 能 省 略 ID 值 。 这 样 可 以 在 不 支持 PHP 的 网 
站 上 调用 该 投票 程序 。 当 然 , 如 果 是 提供 给 普通 用 户 使 用 ， 其 中 的 sre 就 一 定 要 是 绝对 路 径 ， 因 为 用 户 
的 内 容 不 可 能 和 服务 器 上 的 程序 在 一 个 路 径 之 下 。 

另外 ， 单 独 使 用 这 样 的 调用 即 显示 投票 情况 是 会 成 功 的 。 但 要 处 理 这 样 的 提交 结果 ， 就 一 定 要 把 
下 面 要 讲 到 的 提交 处 理 页 面 17-9.php 中 最 后 回 退 的 页 面 改 为 用 户 的 页 面 ， 这 就 需要 程序 在 处 理 时 使 用 
系统 变量 $_SERVER['HTTP_REFERER'] 记 录用 户 上 一 页 的 内 容 ， 然 后 在 处 理 结束 后 重新 返回 用 户 的 
页 面 。 


17.4.6 创建 选择 项 提交 处 理 页 面 


本 节 编 写 对 选择 项 的 提交 进行 处 理 的 页 面 。 该 页 面 实现 的 功能 是 依照 用 户 选择 的 项 目 更 新 相应 记 
录 的 数值 。 具 体内 容 参 看 以 下 代码 : 


<? 
$id=$_POSTIid]; /获取 用 户 提交 的 ID 值 
$v_type=$_POST[v_type]; // 获 取 投 票 项 的 类 型 


$r=$_POST]r]; // 获 取 投 票 项 内 容 
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require "17-1.php"; 
S$link=mysql_connect($db_host,$db_user,$db_pass); 
mysql_select_db($db_name, $link); 


if($v_type==0) // 如 果 投 票 类 型 是 单 选 
{ 
$sql="update $table vote set v_num=v_num+1 where id=$id"; // 更 新 投票 记录 加 1 
mysql_query($sql,$link); 
$sql2="update $table_record set r_num=r_num+1 where id=$r"; // 更 新 选择 支 记 录 加 1 
mysql_query($sql2, $link); 
} 
else // 如 果 投 票 项 是 多 选 
{ 
for($i=0;$i<count($r);$i++) // 通 过 循环 实现 记录 的 更 新 
1 
$sql="update $table vote set v_num=v_num+1 where id=$id"; 
mysql_query($sql,$link); 
$temp=$r[$i]; 
$sql2="update $table_record set r_num=r_num+1 where id=$temp"; 
mysql_query($sql2, $link); 
} 
} 
echo "<html>"; 1/ 处 理 结 束 显示 HTML 内 容 


echo "<head>"; 

echo "<title> 投 票 程序 一 一 处 理 投票 结果 </title>"; 

echo "<meta http-equiv=\"refresh\" content=\"2; url=17-6.php?id=$id\">"; INBE 17-6.php。 

echo "</head>"; 

echo "<body>"; 

echo "投票 成 功 !"; 

echo "<p>"; 

echo "两 秒 后 返回 "; 

echo "</body>"; 

?> 

把 以 上 代码 保存 为 “17-9.php”。 至 此 ， 该 投票 程序 的 全 部 主要 功能 已 经 完成 。17.5 节 开 始 对 所 有 
功能 进行 调试 。 


17.5 测试 程序 


程序 测试 是 程序 编写 完成 后 的 一 个 重要 环节 。 每 个 程序 在 编写 完成 后 都 要 进行 测试 。 通 过 对 代码 
的 测试 ， 可 以 发 现 其 中 的 BUG， 然 后 就 可 以 排除 BUG， 使 程序 更 好 地 运行 。 

在 17.4 节 中 已 经 完成 了 投票 程序 的 全 部 模块 ， 本 节 就 对 17.4 节 所 编写 的 所 有 页 面 进行 测试 ， 以 验 
证 该 程序 是 否 能 正常 运行 。 操 作 步 骤 如 下 : 

(1) 由 于 准备 工作 配置 文件 、 创 建 表 的 工作 ) 在 17.4.1 小 节 中 已 经 完成 ， 所 以 本 节 就 直接 从 显 
示 投 票 项 开始 。 第 1 步 ， 在 PHP 执行 环境 中 运行 17-3.php， 将 显示 如 图 17.2 所 示 的 结果 。 因 为 ， 虽 然 
已 经 创建 了 相应 的 表 ， 但 是 表 中 并 没有 任何 记录 ， 所 以 图 17.2 才 显 示 现 在 还 没有 记录 的 结果 。 这 时 没 
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有 别 的 选择 ， 只 有 单 击 链接 “添加 记录 ”， 来 添加 投票 记录 ， 即 执行 17-4.php。 其 执行 结果 如 图 17.3 
所 示 。 


ani TE 
| XPO SRO FEV KAW IAV HW | & 
E] 
投票 程序 一 一 增加 投票 项 第 一 步 
私 投 票 程序 一 一 时 示 所 有 投票 项 一 
[XED RED FEV KAN IAV 帮助 0 > 投票 项 属性 
习 —. 
本 H- = fi 内 容 ; 
投票 程序 一 一 显示 所 有 投票 项 ER CHE CSE 
FMR AE 全 
现在 还 没有 记录 1 É a 4 
Ed mm IO 4] [BE ml Ey YA 


图 17.2 第 一 次 运行 显示 投票 项 页 面 时 的 结果 


图 17.3 ”增加 投票 项 第 一 步 执行 结果 


Q) 由 于 17-4.php 把 增加 投票 项 的 3 步 操 作 化 为 了 一 步 ， 所 以 第 1 步 操作 执行 时 ， 将 会 发 现 如 
图 17.3 所 示 的 提示 。 下面 开始 按 需 要 创建 新 的 投票 项 。 这 里 投票 项 的 内 容 定 为 :“ 你 对 本 站 印象 如 何 ”; 
投票 项 的 类 型 为 单 选项 ， 投 票 项 的 项 数 选择 3 项 。 然 后 ， 单 击 “ 下 一 步 ” 按 钮 ， 就 会 转 到 增加 投票 项 
的 第 2 步 。 第 2 步 的 显示 结果 如 图 17.4 所 示 。 

(3) 由 于 在 上 一 步 选择 了 3 项 选择 项 ， 所 以 这 一 步 就 是 确定 每 项 选择 项 的 内 容 。 这 里 分 别 填 入 好 
极 了 、 很 一 般 、 粳 透 了 3 项 内 容 。 颜 色 分 别 选用 : 红 、 黄 、 蓝 3 种 颜色 。 按 照 要 求 填写 完成 相应 项 目 
后 ， 再 单 击 “ 下 一 步 ” 按 钮 ， 就 转 到 了 增加 投票 项 的 第 3 步 。 由 于 第 3 步 的 操作 是 把 相应 记录 添加 到 
RP, 所 以 执行 都 是 在 后 台 运 行 。 执 行 完毕 后 ,直接 跳 转 到 了 “显示 所 有 投票 项 ”的 页 面 ,， 即 17-3.php。 
跳 转 后 的 结果 如 图 17.5 所 示 。 
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投票 程序 一 一 增加 投票 项 第 二 步 


四 及 于 程序 一 一 旦 示 所 有 投票 顶 - 


投票 项 每 项 选择 项 属性 [IFO RAD SEVU WBW IAV MBW | a 
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MTA me ma] Bizz 
Wema aa A ER 
+] Tæ] MA Ku pa 
EE [ml ml ml ml Er = 后 M 3 


图 17.4 增加 投票 项 第 二 步 执行 结果 17.5 添加 完投 票 项 后 的 显示 投票 项 页 面 


(4) 通过 图 17.5 的 执行 结果 可 以 看 到 ， 已 经 正常 显示 出 了 前 面 添加 过 的 投票 项 “你 对 本 站 印象 如 
何 ”。 这 说 明 程 序 正 常 运行 。 单 击 投票 项 名 称 的 链接 ， 将 会 转 到 显示 投票 项 的 页 面 ， 即 相当 于 执行 
17-6.php。 执 行 结 果 如 图 17.6 所 示 。 

(5) 从 图 17.6 可 以 看 出 , 投票 程序 正确 地 显示 了 投票 项 及 其 选择 项 的 内 容 。 由 于 此 时 并 没有 任何 
的 票 ， 或 者 说 没有 做 任何 的 选择 ， 所 以 每 一 个 选择 项 的 选择 次 数 都 是 0 次 。 下 面 尝试 选择 图 17.6 中 的 
“好 极 了 ”， 然 后 确认 提交 。 由 于 该 页 表单 的 action 属性 指向 17-9.php， 所 以 将 会 调用 17-9.php 来 处 
理 提 交 结 果 。 


第 17 章 ”网 上 投票 程序 329“ 


(6) 像 上 面 添加 记录 一 样 处 理 页 面 更 新 表 中 的 内 容 ， 即 把 vote 中 的 v_num 增加 1， 再 把 record 
中 的 相应 项 的 r num 增加 1。 处 理 完 成 后 ， 将 返回 显示 投票 项 详细 信息 的 页 面 。 处 理 结果 如 图 17.7 
所 示 。 
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图 17.6 显示 投票 项 详细 信息 页 面 图 17.7 显示 投票 项 的 投票 结果 


每 一 项 投票 结果 都 被 正确 地 显示 了 出 来 。 说 明 该 程序 正确 处 理 了 用 户 提 交 的 投票 结果 。 

D 本 步 又 测试 一 下 多 项 选择 是 否 能 正确 执行 。 先 运行 17-4.php 创建 一 个 多 项 投票 项 ， 如 标题 
为 : “你 觉得 本 站 还 应 增加 哪些 内 容 ”; 选择 项 为 “游戏 ”、“ 动 漫 ”、“ 软 件 ”、“ 硬 件 ”、“ 小 
说 ”、“ 玄 幻 ”、“ 体 育 ”。 把 每 一 项 都 设 定 相 应 的 颜色 ,创建 好 以 后 的 显示 信息 如 图 17.8 所 示 。 

(8) 下 面 分 别 一 次 选择 其 中 的 多 项 内 容 ， 以 测试 多 选项 是 否 成 功 执行 。 执 行 结果 如 图 17.9 所 示 。 
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图 17.8 显示 多 选 投票 项 详细 情况 图 17.9 显示 多 项 投票 项 投票 结果 


(9) 如 图 17.9 所 示 ， 如 果 用 户 一 次 选择 4 项 ， 就 会 当 作 单 选 4 次 的 投票 被 计 入 库 中 。 而 每 被 投 中 
的 一 次 将 会 作为 一 次 投票 。 经 测试 达到 了 正确 处 理 多 项 选择 的 目的 ， 即 把 一 次 多 选 的 几 项 当 作 几 次 计 
数 ， 如 一 次 多 选 了 多 项 内 容 ， 就 当 作 多 次 计数 。 

(10) 重新 回 到 17-3.php， 测 试 删除 投票 项 的 功能 。 在 执行 删除 操作 之 前 ， 共 有 两 条 投票 项 〈 即 
测试 时 添加 的 两 条 ) ， 如 图 17.10 所 示 。 

(11) 单 击 其 中 一 条 后 面 对 应 的 删除 链接 ， 将 会 执行 17-9.php。 该 页 面 的 功能 是 把 参数 ID 所 对 应 
的 投票 项 及 其 在 record 表 中 的 所 有 选择 项 全 部 删除 。 在 执行 完全 部 操作 后 ， 又 会 自动 跳 回 到 17-3.php。 
所 以 只 有 通过 操作 前 后 的 对 比 ， 才 能 发 现 程序 是 否 正确 执行 。 其 结果 如 图 17.11 所 示 。 
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图 17.10 删除 前 的 所 有 投票 项 17.11 删除 后 的 所 有 投票 项 


(12) 通过 对 图 17.10 与 17.11 的 对 比 可 以 发 现 第 2 条 记录 不 见 了 ， 表 示 它 已 经 被 成 功 删 除了 。 
(13) 下 面 测试 JS 调用 页 面 的 功能 。 要 测试 这 项 功能 ， 直 接 在 浏览 器 地 址 栏 中 运行 17-8.php。 其 
结果 如 图 17.12 所 示 。 
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图 17.12 使 用 JS 调用 页 面 的 执行 结果 
(14) 通过 图 17.12 可 以 看 出 ， 通 过 JS 调用 ， 显 示 出 了 与 直接 使 用 显示 投票 项 页 面 几乎 完全 一 致 
的 内 容 。 说 明 该 功能 也 正常 。 需 要 注意 的 是 ， 当 用 户 使 用 JS 调用 的 页 面 ， 提 交 时 必须 要 把 17-9.php 处 
理 操作 结束 后 所 要 回转 的 页 面 地址 做 一 下 改动 。 使 用 系统 变量 $_ SERVER[HTTP_REFERER']， 重 新 返 
回 用 户 的 页 面 。 
至 此 ， 该 投票 系统 的 所 有 功能 全 部 测试 完毕 。 


17.6 ”如 何 防止 重复 投票 


投票 程序 该 具有 的 功能 已 经 全 部 都 有 了 ， 但 还 是 不 很 完善 ， 因 为 它 不 能 限制 用 户 重 复 投票 。 这 里 
给 出 一 个 改进 思路 。 由 于 实现 起 来 相当 简单 ， 对 于 学 过 本 书 的 读者 已 经 完全 有 能 力 自己 解决 ， 所 以 这 
里 也 就 不 再 给 出 代码 ， 有 兴趣 的 读者 可 以 自己 通过 实践 来 解决 。 

还 记得 17-1.php 那个 Sre_vote (重复 投票 ) 变量 吗 ? 在 执行 17-9.php 处 理 用 户 提交 操作 之 前 ， 先 来 
判断 该 值 ， 如 果 该 值 设 定 为 True， 即 允许 用 户 重 复 投票 ， 就 不 执行 任何 操作 。 如 果 该 值 为 False， 则 先 
判断 有 无 某 个 Cookie 值 ， 如 果 没 有 ， 把 用 户 IP 写 入 某 个 Cookie 值 (如何 获得 用 户 耳 ， 请 参阅 本 书 第 
9 章 的 内 容 ) 。 如 果 存 在 该 cookie 值 ， 则 把 用 户 的 IP 与 该 值 相 比较 ， 如 果 二 者 不 一 致 就 继续 执行 下 面 
的 操作 ， 如 果 二 者 一 致 就 给 出 不 允许 重复 投票 的 提示 ， 并 且 使 用 exitO 函 数 中 止 所 有 PHP 语句 的 执行 。 


第 17 章 ”网 上 投票 程序 "331。 


这 样 一 来 就 可 以 有 效 防 止 用 户 的 重复 投票 ， 这 样 既 增加 了 投票 结果 的 真实 性 、 可 信 度 又 可 以 减轻 
服务 器 的 负担 。 


17.7 本 章 小 结 


本 章 完成 了 一 个 网 上 投票 程序 。 通 过 对 本 章 的 学 习 ， 一 方面 复习 了 数据 库 的 知识 ， 另 一 方面 也 使 
读者 了 解 到 了 如 何 采用 不 同 的 方法 来 解决 相同 的 问题 ， 进 一 步 增强 了 读者 使 用 PHP 来 处 理 实际 问题 的 
能 力 。 但 是 ， 本 章 所 举 的 投票 程序 的 例子 毕竟 还 只 是 十 分 简单 的 一 个 实例 ， 实 际 应 用 时 投票 程序 往往 
需要 有 多 方面 的 要 求 。 但 不 管 它们 的 功能 有 多 么 丰富 ， 内 容 有 多 么 复杂 ， 其 最 核心 的 内 容 还 是 对 数据 
库 表 的 操作 。 相 信 读 者 通过 本 章 的 学 习 ， 加 上 自己 的 思考 与 努力 ， 一 定 能 写 出 高 效 、 简 洁 的 网 上 投票 
程序 。 
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留言 板 在 网 络 上 有 着 极为 广泛 的 应 用 , 它 是 沟通 网 站 管理 人 员 与 普通 浏览 者 的 一 个 
强 有 力 的 纽带 。 不 论 是 个 人 的 小 型 网 站 ， 还 是 企业 的 大 型 站 点 ， 到 处 都 可 以 发 现 留 言 板 
的 影子 。 如 果 一 个 网 站 中 没有 了 留言 板 ， 那 就 无 法 和 普通 浏览 的 用 户 进行 有 效 的 沟通 。 
因为 留言 板 有 如 此 广泛 的 应 用 ,所 以 ,编写 留言 板 , 就 是 编写 大 型 Web 应 用 程序 的 基础 。 

这 一 章 将 向 读者 介绍 如 何 编 写 一 个 文本 型 的 留言 板 。 本 章 内 容 包 括 以 下 几 个 部 分 ， 
留言 板 分 类 、 文 本 留言 板 的 实现 原理 、 留 言 板 实例 的 构成 、 留 言 板 配 置 文件 的 建立 、 编 
写 显 示 留 言 板 及 提交 留言 页 、 后 台 修改 留言 功能 的 实现 、 后 台 删 除 留言 功能 的 实现 以 及 
进一步 完善 等 内 容 。 通 过 本 章 的 学 习 ， 会 使 读者 事 握 如 何 编写 PHP 文本 留言 板 。 
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18.1 留言 板 分 类 


留言 板 是 网 络 上 使 用 最 广 的 互动 Web 应 用 程序 之 一 。 由 于 其 使 用 灵活 、 方 法 简单 、 用 户 与 管理 者 
之 间 互 动 效果 明显 ， 所 以 一 直 深 受 网 络 管理 者 与 使 用 者 的 欢迎 。 网 上 常见 的 留言 板 按照 它们 的 存储 机 
制 的 不 同 ， 大 致 可 以 分 为 以 下 两 大 类 : 文本 型 留言 板 和 数据 库 型 留言 板 。 这 一 节 为 读者 分 别 作 介绍 。 


18.1.1 文本 型 留言 板 


顾名思义 ， 所 谓 文本 型 留言 板 就 是 采用 文本 文件 作为 数据 存储 方式 的 一 类 留言 板 。 文 本 留言 板 由 
于 采用 文本 文件 作为 数据 存储 的 载体 ， 所 以 与 其 他 类 型 的 留言 板 相 比较 ， 具 有 几 下 几 个 特征 。 
口 ”由 于 不 需要 数据 库 支 持 ， 所 以 文本 留言 板 只 要 服务 提供 商 支持 普通 PHP 程序 ， 就 可 以 使 用 。 
O 与 其 他 类 型 留言 板 程序 相 比 ， 可 移植 性 强 。 数 据 备份 也 更 为 简单 ， 只 需要 将 相应 数据 文件 备 
份 即 可 。 
口 文本 留言 板 在 处 理 内 容 比 较 少 的 数据 时 往往 速度 比较 快 ， 但 是 在 处 理 大 量 数 据 ， 如 留言 数据 
达到 成 十 上 万 的 数量 级 时 就 会 显得 力不从心 。 
O ”由 于 没有 专门 的 函数 ， 所 以 与 数据 库 留言 本 相 比 ， 插 入 、 修 改 、 删 除 记录 操作 起 来 相对 要 麻 
烦 一 些 。 
口 ” 由 于 文本 留言 板 的 数据 采用 纯 文本 的 方式 进行 排列 ， 所 以 记录 的 检索 起 来 也 不 如 数据 库 留 言 
板 那么 方便 。 
以 上 列 出 了 文本 留言 板 的 几 个 特点 ， 可 见 与 其 他 类 型 的 留言 板 相 比 起 来 ， 也 有 不 足 之 处 。 但 它 的 
优点 也 是 相当 明显 的 , 所 以 , 文本 留言 板 还 是 在 网 络 上 有 相当 多 的 拥护 者 。 这 也 是 这 一 章 所 要 介绍 的 重点 。 


18.1.2 ”数据库 型 留言 板 


文本 型 留言 板 固然 有 很 多 优点 ， 但 不 足 之 处 也 是 显而易见 的 。 如 不 具备 搜索 功能 ; 插入 、 修 改 、 
删除 留言 相对 比较 麻烦 等 。 这 些 不 足 ， 在 数据 库 型 留言 板 中 可 以 非常 轻松 地 解决 。 由 于 数据 库 型 留言 
板 采 用 数据 库 作 为 数据 载体 ， 所 以 插入 、 修 改 、 删 除 留言 时 只 需 执 行 相应 的 SQL 语句 即 可 。 而 留言 搜 
索 更 是 可 以 轻松 实现 。 下 面 来 了 解 一 下 数据 库 型 留言 板 的 特点 。 
O 数据 库 留言 板 是 以 数据 库 、 数 据 表 作 为 留言 数据 的 存储 载体 的 一 类 留言 板 程序 的 统称 。 用 数 
据 库 作 为 数据 载体 ， 相 对 于 文本 型 留言 板 来 说 ， 它 的 优点 非常 明显 。 但 与 之 相 比 ， 缺 点 也 是 
显而易见 的 。 
O ”使 用 数据 库 作为 载体 ， 在 处 理 留 言 信息 时 速度 很 快 ， 特 别 是 在 处 理 大 量 数据 时 ， 速 度 优势 更 
为 明显 。 
O 有 PHP 数据 库 函数 库 的 支持 ， 依 托 高 效 SQL 的 语句 ， 数 据 库 型 留言 板 实现 数据 插入 、 修 改 、 
删除 等 操作 都 非常 方便 快捷 。 
O “留言 记录 搜索 功能 对 于 数据 库 型 留言 板 来 说 更 是 小 菜 一 碟 。 甚 至 它 可 以 支持 任何 字段 的 模糊 
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查找 。 
口 ”由 于 需要 数据 库 支持 ， 所 以 对 服务 提供 商 要 求 较 多 ， 一 旦 服务 供应 商 不 支持 这 项 服务 ， 那 么 
这 种 类 型 的 留言 板 将 无 法 运行 。 


口 可 移植 性 与 文本 留言 板 比 较 起 来 较 差 。 在 一 个 空间 运行 正常 的 程序 到 了 另 一 个 地 方 ， 就 要 修 
改 相关 配置 选项 。 而 文本 留言 板 几乎 可 以 不 做 任何 修改 即 可 以 在 不 同 的 空间 上 正常 运行 。 

O 相对 文本 留言 板 来 说 , 数据 备份 相对 麻烦 。 虽然 有 高 效 的 数据 库 管理 程序 , 如 PHPMYADMIN 
之 类 的 可 以 轻松 实现 数据 库 的 导出 导入 ， 但 对 于 只 使 用 复制 、 粘 贴 就 可 以 轻松 备份 的 文本 留 
言 板 来 说 还 是 显得 有 些 麻烦 。 

以 上 列 出 了 数据 库 留 言 板 的 一 些 特点 。 通 过 对 比 可 以 发 现 ， 两 种 留言 板 互 有 长 短 ， 互 为 补充 ， 不 
能 说 哪 种 比 哪 种 更 优秀 ， 要 看 用 在 什么 环境 下 。 

如 果 是 个 人 用 户 ， 推 荐 使 用 文本 型 留言 板 ， 因 为 该 种 类 型 留言 板 小 巧 玲珑 ， 管 理 方便 。 在 留言 数 
量 相对 少 的 情况 下 使 用 者 能 体会 到 文本 留言 板 的 快捷 与 便利 。 如 果 是 企业 级 的 用 户 ， 还 是 推荐 使 用 数 
据 库 型 留言 板 。 对 于 企业 服务 器 来 说 ， 数 据 库 支持 不 是 问题 。 另 外 企业 也 不 可 能 经 常 更 换 服务 器 或 者 
空间 ， 可 移植 性 与 数据 备份 的 麻烦 可 以 忽略 不 计 。 最 主要 的 是 使 用 数据 库 型 留言 板 ， 可 以 使 用 数据 库 
的 强大 功能 ， 并 且 数 据 存 储量 可 以 不 受 限制 。 

这 一 节 ， 留 言 板 的 类 型 就 介绍 到 这 里 ， 从 18.2 节 开始 就 来 为 读者 介绍 如 何 具体 实现 PHP 文本 留 


18.2 文本 留言 板 的 实现 原理 


这 一 节 将 介绍 一 下 文本 留言 板 的 实现 原理 。 

文本 留言 板 ， 把 用 户 输入 的 数据 存 入 一 个 文本 文件 。 虽 说 是 文本 文件 ， 但 这 个 文件 的 扩展 名 不 一 
定 是 txt。 它 可 以 是 任意 的 扩展 名 ， 如 php、dat、gif、mp3、jpg、rm， 甚 至 可 以 不 加 任何 扩展 名 。 用 户 
输入 数据 的 存储 格式 一 般 是 一 条 记录 占用 一 行 ， 每 一 行 都 有 一 个 行 标 ， 以 及 所 输入 的 各 项 内 容 。 各 项 
内 容 之 间 使 用 特殊 符号 将 它们 分 隔 开 来 。 特 殊 符号 ， 可 以 自由 定义 ， 但 是 为 了 区 别 于 普通 输入 内 容 ， 
一 般 不 采用 标准 的 字符 ， 而 是 用 一 些 通常 不 常用 到 的 字符 ， 如 “||”、“@@”、“~~”、“***”、 
“$$$” 等 。 如 下 面 这 一 段 就 显示 了 一 行文 本 留言 板 的 记录 : 

15||JACKlljjack@hotmail.coml| 欢 迎 大 家 来 到 这 里 并 留言 ! <br> 我 祝 大 家 心情 愉快 ， 工 作 顺利 ! ||2006 年 10 月 5 

日 11:42|1127.0.0.1 

通过 查看 上 面 的 内 容 可 以 发 现 ， 该 文本 留言 板 程序 使 用 了 “||” 来 分 割 用 户 所 输入 的 各 项 内 容 。 各 
项 内 容 的 含义 大 致 如 下 所 示 : 


15 行 号 

JACK 姓名 
jack@hotmail.com 电子 信箱 
欢迎 大 家 来 …… 留言 内 容 
2006 年 10 月 5 日 11:42 留言 日 期 及 时 间 


127.0.0.1 IP 地 址 


+336 > 


PHP 网 络 编程 从 入 门 到 精通 


将 留言 内 容 按 特定 格式 存 入 文本 文件 ， 在 需要 显示 时 ， 再 按照 相应 的 格式 显示 出 来 即 可 。 

另外 一 点 就 是 文本 留言 板 的 分 页 显示 。 它 不 像 数据 库 那样 读 取 相应 的 记录 即 可 。 文 本 留言 板 分 页 
的 实现 原理 是 读 取 相应 的 行 。 如 一 共有 25 条 记录 ， 共 分 25 行 。 如 果 是 第 1 页 ， 就 显示 第 25 到 第 16 
条 记录 ; 如 果 是 第 2 页 就 显示 第 15 到 第 6 条 记录 ; 如 果 是 第 3 页 就 显示 第 5 到 第 1 条 记录 , 依次 类 推 。 
这 样 就 可 以 实现 多 页 的 显示 了 。 

还 有 就 是 修改 与 删除 留言 数据 ， 与 数据 库 留 言 板 相 比 ， 也 是 有 点 麻烦 。 需 要 对 相应 的 记录 读 出 ， 
后 按 要 求 进行 修改 或 者 删除 操作 。 


这 一 


节 ， 关 于 文本 留言 板 的 基本 实现 原理 就 讲 到 这 里 。 


18.3 文本 留言 板 实例 的 组 成 


现 介 绍 本 章 要 讲 到 的 文本 留言 板 实例 的 组 成 。 
下 面具 体 列举 一 下 留言 板 系统 的 组 成 ， 及 每 个 文件 的 作用 。 
将 要 讲解 到 的 文本 留言 板 程序 由 以 下 文件 组 成 。 


口 


口 


口 


口 


口 


15-1.php， 是 系统 的 配置 文件 ， 里 面 放置 儿 个 重要 的 全 局 变量 。 包 括 文件 名 、 管 理 者 密码 、 每 
页 显示 的 留言 条 数 等 内 容 。 

15-2.php， 是 系统 的 最 主要 的 文件 。 该 文件 把 留言 显示 、 留 言 的 提交 前 台 、 留 言 的 提交 后 台 处 
理 3 项 功能 整合 到 一 个 文件 之 中 。 这 样 做 既 减 少 了 文件 个 数 ， 又 便于 管理 。 

15-3.php， 是 系统 管理 的 登录 页 。 通 过 该 文件 , 管理 者 可 以 登录 到 服务 器 然后 注册 Cookie。 然 
后 就 可 以 对 留言 执行 修改 、 删 除 等 操作 。 

15-4.php， 是 系统 的 修改 留言 处 理 页 面 。 在 执行 修改 操作 前 会 先 判断 Cookie 值 ， 如 果 Cookie 
值 与 系统 配置 文件 (15-1.php) 中 给 定 的 不 一 致 ， 返回 错误 提示 。 如 果 正 确 就 会 执行 修改 操作 。 
15-5.php， 系 统 的 删除 留言 处 理 页 面 。 在 执行 删除 操作 前 会 先 判断 Cookie 值 ， 如 果 Cookie 值 
与 系统 配置 文件 〈15-1.php) 中 给 定 的 不 一 致 ， 返 回 错 误 提 示 。 如 果 正 确 就 执行 删除 操作 。 


该 文本 留言 板 程序 ， 就 由 以 上 儿 个 文件 组 成 。 从 18.4 节 开 始 ， 逐 个 来 为 读者 做 介绍 。 


18.4 文本 留言 板 代码 的 实现 


前 面 儿 节 讲 到 了 留言 板 的 分 类 、 文 本 留言 板 的 实现 原理 以 及 要 讲 到 的 文本 留言 板 的 构成 。 这 些 都 
是 为 本 节 要 讲 到 的 内 容 做 准备 。 这 一 节 ， 将 一 个 模块 一 个 模块 地 实现 整个 系统 的 功能 。 


18.4.1 


配置 文件 的 建立 


这 一 小 节 ， 带 领 读者 来 创建 文本 留言 板 系统 的 配置 文件 。 配 置 文件 在 程序 运行 时 起 关键 作用 。 因 
为 该 文件 定义 了 几 个 对 系统 运行 起 关键 作用 的 全 局 变量 。 它 决定 了 系统 所 使 用 的 存储 数据 的 文件 名 、 
管理 者 对 留言 进行 管理 〈 修 改 、 删 除 操作 ) 登录 时 所 使 用 的 密码 、 显 示 留 言 页 每 页 显示 的 留言 条 数 等 
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内 容 。 
以 下 是 该 配置 文件 的 全 部 内 容 : 
<? 
$file name-"data.dat"; /数据 文件 名 
$super pass-"super man"; /管理 员 名 称 
$list num=10; /| 每 页 显示 留言 数 
7> 


把 以 上 代码 保存 为 “18-1.php”， 以 备 后 用 。 


18.4.2 ”显示 提交 留言 文件 建立 


这 一 小 节 要 来 创建 文本 留言 板 系统 的 留言 显示 文件 。 由 于 使 用 了 整合 功能 ， 所 以 该 文件 还 包含 留 
言 提交 前 后 、 留 言 提交 后 台 等 功能 。 可 以 说 该 文件 是 整个 系统 中 最 为 重要 的 一 个 文件 。 如 果 不 需要 留 
言 修 改 、 留 言 删除 的 功能 ， 只 要 最 简单 的 发 布 留言 、 查 看 留言 功能 ， 那 么 只 需要 这 一 个 文件 就 已 经 够 
了 。 可 见 该 文件 在 整个 系统 中 的 重要 地 位 。 

一 般 常 见 的 显示 与 提交 留言 在 一 起 的 情况 是 页 面 上 半 部 分 显示 留言 ， 下 面 有 一 个 表单 供用 户 输入 

言 。 这 种 情况 很 方便 ， 但 影响 美观 。 这 里 要 做 的 是 使 用 JavaScript 技术 ， 把 用 户 提交 留言 的 表单 放置 

到 一 个 层 中 。 用 户 浏览 留言 时 ， 该 层 是 隐藏 的 ， 只 有 当 用 户 需 要 留言 ， 并 按 下 相应 链接 时 ， 才 出 现 该 
层 。 关 于 层 的 隐藏 与 显示 属于 JavaScript 的 内 容 ， 不 在 本 书 讨论 范围 ， 有 兴趣 的 读者 ， 可 以 查找 相关 书 
籍 。 这 里 只 提供 相关 功能 并 不 做 具体 说 明 。 

下 面 开始 具体 创建 该 文件 : 

<? 

require "18-1.php"; 

if(!$_POST[name]) /如 果 没有 数据 提交 ， 则 显示 记录 


?> 

<html> 

<head> 

<title> 文 本 留言 板 一 一 记录 显示 页 </title> 
<script language=javascript> 


function Showhide(id,flag) 
if(flag==1) 
{ 
id.style.display="; 
} 
if(flag==0) 
{ 
id.style.display-'none'; 
} 
} 
</script> 


</head> 
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<body> 
<center> 
<h1> 文 本 留言 板 一 一 记录 显示 页 </h1> 


<p> 


<a href=# onClick="Showhide(huifu,1)"> 签 写 留言 </a>&nbsp;&nbsp;<a href=18-3.php> 管 理 入 口 </a> 


<p> 

<? 

if(!$_GET["page"]) 

$page=1; 

else 

$page=$_GET["page"]; 

if(tfile_exists($file_name)) 

{ 
$fp=fopen($file_name,"w"); 
fclose($fp); 


} 

$myfile-file($file name); 

if($myfile[0]=="") 

echo "目前 记录 条 数 为 :，0"; 

else 

{ 
S$temp=explode("||",$myfile[0]); 
echo "共有 ".$temp[0]." 条 内 容 "; 
echo "&nbsp;&nbsp;&nbsp;&nbsp;"; 
$p_count=ceil($temp[0]/$list_num); 
echo "分 ".$p_count." 页 显示 "; 
echo "&nbsp;&nbsp;&nbsp;&nbsp;"; 
echo "当前 显示 第 ".$page." 页 "; 
if($page!=ceil($temp[O]/S$list_num)) 
$current_size=$list_num; 
else 
$current_size=$temp[0]%$list_num; 
if($current_size==0) 
$current_size=$list_num; 
echo "<table border='1'>"; 
for($i=0;$i<$current_size;$i++) 


{ 


/如 果 没 有 参数 page 
// 则 显示 第 一 页 内 容 


// 如 果 带 有 参数 page， 则 显示 相应 页 内 容 
// 如 果 是 第 一 次 运行 〈 文 件 不 存在 ) 


/创建 文件 


/使 用 file() 函 数 把 所 有 信息 读 入 一 个 数组 
/如 果 文 件 为 空 ， 即 没有 任何 留言 信息 
/显示 没有 记录 的 信息 


// 读 出 数组 第 一 条 记录 到 数组 
// 读 出 该 数组 第 一 个 元 素 〈 代 表 记 录 总 条 数 ) 


// 计 算 总 页 数 为 记录 总 条 数 除 以 每 页 显示 条 数 
// 输 入 总 页 数 


// 当 前 页 

// 如 果 当 前 页 不 是 最 后 一 页 

// 当 前 页 最 多 可 显示 $list_num 条 记录 

// 如 果 当 前 页 是 最 后 一 页 

// 当 前 页 显示 的 条 数 为 总 条 数 除 以 $lsit_num 的 余数 


// 如 果 正好 是 显示 条 数 的 倍数 则 显示 $list_num 条 内 容 


$temp=explode("||",$myfile[($page-1)*$list_num+i]);// 把 相应 的 记录 按 “|| ”分割 到 数组 


echo "<tr>"; 
echo "<td>"; 
echo "第 ".$temp[0]." 条 留言 "; 
echo "</td>"; 
echo "<td>"; 
echo "作者 : ".$temp[1]; 
echo "</td>"; 
echo "<td>"; 
echo " 写 于 ".$temp[4]; 


if($_COOKIE[pass]==$super_pass) 


{ 


/显示 记录 号 


/显示 作者 


/显示 留言 时 间 
// 如 果 管理 者 登录 ， 则 显示 操作 连接 
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echo "<a href='18-4.php?i 
echo "&nbsp;&nbsp;"; 
echo "<a href='18-5.php?id=".$temp[0]."> 删 除 </a>"; 


".$temp[0]."> 修 改 </a>"; 


} 
echo "</td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td colspan='3'>"; 
echo "主题 : ".$temp[2]; /显示 留言 主题 
echo "</td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td colspan='3'>"; 
echo "内 容 : <br>".$temp[3]; // 显 示 留 言 内 容 
echo "</td>"; 
echo "</tr>"; 
} 
echo "</table>"; 
} 
echo "<p>"; 
?> 
<div id="huifu" style="display:none; position:absolute; left:15px; top:265px;"> 
<table border=1 bgcolor="#ffffff'> 
<form method="post" action=<?echo $PATH_INFO?>> 
<tr> 
<td colspan="2"> 请 输入 留言 内 容 </td> 
</tr> 
<tr> 
<td> 姓 名 : </td> 
<td><input name="name" type="text"></td> 
</tr> 
<tr> 
<td> 主 题 : </td> 
<td><input name="subject" type= "text"></td> 
</tr> 
<tr> 
<td colspan="2"> 内 容 : </td> 
</tr> 
<tr> 
<td colspan="2"> 
<textarea name="content" cols="36" rows="8"></textarea> 


ubmit" name="Submit" value=" 确 定 "> 

<input type="reset" name="Submit2" value=" 清 除 "> 

<input name="Submit3" type="button" onClick="Showhide(huifu,0)" value=" 关 闭 "> 
</td> 
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</tr> 
</form> 
</table> 
</div> 
<? 
/以 下 内 容 为 分 页 显示 连接 
$prev page-$page-1; // 前 一 页 
$next_page=$page+1; /下 一 页 
if ($page<=1) 
{ 
echo "第 一 页 |"; 
} 
else 
{ 
echo "<a href='$PATH_INFO?page=1'> 第 一 页 </a> |" 
} 
if ($prev_page<1) 
{ 
echo "上 一 页 | "; 
} 
else 
echo "<a href='$PATH_INFO?page=$prev_page'> 上 一 页 </a> |" 
J 
if ($next_page>$p_count) 


echo "下 一 页 | "; 
} 


else 


{ 


} 
if ($page>=$p_count) 


echo "<a href='$PATH_INFO?page=$next_page'> 下 一 页 </a> | "; 


{ 
echo "最 后 一 页 </p>\n"; 

} 

else 

{ 
echo "<a href='$PATH_INFO?page=$p_count> 最 后 一 页 </a></p>\n"; 

} 

} 

else 

{ 
$name=$_POSTIname]; // 获 取 作者 
$subject=$_POST[subject]; // 获 取 主 题 
$content=$_POST[content]; // 获 取 内 容 
$time= date(Y 4 m F d A); // 获 取 日 期 


$s=$name."||".$subject."||".$content."||".$time."\n"; // 把 内 容 赋 值 给 变量 
$myfile-file($file name); /使 用 file() 把 记录 文件 按 行 读 入 数组 
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if($myfile[0]=="™" 

{ 
S$fp=fopen($file_name,"a+"); 
fwrite($fp,"1||".$s); 
fclose($fp); 

} 

else 

{ 
S$temp=explode("||",$myfile[0]); 
$temp[0]++; 
S$fp=fopen($file_name,"r"); 


$line_has=fread($fp,filesize("$file_name")); 


fclose($fp); 
$fp=fopen($file_name,"w'"); 
fwrite($fp, $temp[0]."||".$s); 
fwrite($fp,"$line has"), 
fclose($fp); 
} 

?> 

<html> 

<head> 

<title> 文 本 留言 板 一 一 记录 添加 页 </title> 

</head> 


<meta http-equiv="refresh" content="2; url=18-2.php"> 


<body> 

已 经 成 功 更 改 记录 ， 两 秒 后 返回 。 
</body> 

</html> 

<? 

} 


?> 
</body> 
</html> 


把 以 上 代码 保存 为 “18-2.php”， 以 备 后 用 。 
通过 查看 以 上 代码 ， 可 以 发 现 主要 是 使 
读 入 到 数组 等 。 下 面 继续 创建 其 他 文件 。 


1843 ”管理 入 口 页 的 创建 


// 如 果 文 件 为 空 


// 写 入 方式 打开 文件 
// 直 接 写 入 行 号 为 1 的 内 容 
// 关 闭 文件 


// 把 第 一 条 记录 按 “||” 分 割 到 数组 

// 得 出 总 记录 数 并 自 增 1 
/以 只 读 方式 打开 文件 

INEM fread 读 出 文件 已 经 存在 的 内 容 
/关闭 文件 

/以 写 入 方式 打开 文件 

// 写 入 新 的 内 容 

// 写 入 原来 已 经 存在 的 内 容 

/关闭 文件 


了 对 文件 的 操作 ， 包 括 按 行 读 取 文件 内 容 ， 把 文件 内 容 


管理 入 口 页 的 作用 是 把 有 管理 权限 的 登录 资料 保存 为 Cookie， 以 便 管 理 者 对 留言 信息 做 相应 的 修 


改 。 登 录 密 码 从 配置 文件 15-1.php 中 获取 。 


下 面 就 来 创建 该 文件 。 具 体内 容 参 看 以 下 代码 : 


=? 
if(!$_POST[pass]) 


/如果 没 有 输入 管理 员 名 称 ， 则 显示 HTML 内 容 
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?> 

<html> 

<head> 
<title> 管 理 入 口 </title> 
</head> 

<body topmargin="50" > 
<script language=javascript> 


function juge(form) 

{ 
if (form.pass.value == "") 
{ 


alert(" 请 输入 密码 !”); 
theForm.pass.focus(); 
retum (false); 
} 
} 
</script> 
<center> 
<h1> 管 理 留言 板 入 口 </h1> 
<p> 
<a href="18-2.php"> 返 回首 页 </a> 
<table border="1"> 
<form action=<?echo $PATH_INFO?> method=post onsubmit="retum juge(this)"> 
<tr> 
<td colspan="2"><center> 管 理 留言 板 </center></td> 
</tr> 
<tr> 
<td> 密 码 </td> 
<td><input type=password name=pass></td> 
</tr> 
<tr> 
<td colspan="2"><center><input type=submit value=" 登 录 "></center></td> 
</tr> 
</form> 
</table> 
</center> 
</body> 
</html> 
<? 


else // 如 果 存 在 密码 ， 则 执行 操作 


require "18-1.php"; // 调 用 配置 文件 
if($_POST[pass]!=$super_pass) // 如 果 密码 错误 
?> i 
<html> 
<head> 
<title> 文 本 留言 板 一 一 管理 入 口 </title> 
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</head> 
<meta http-equiv="refresh" content="2; url=18-3.php"> 
<body> 
登录 失败 ， 密 码 错误 ! <p> 
两 秒 后 返回 。 
</body> 
</html> 
<? 
} 
else // 如 果 密 码 正 确 
{ 
setcookie("pass","$ POST[pass]"); IREA Cookie 
?> 
<html> 
<head> 
<title> 文 本 留言 板 一 一 管理 入 口 </title> 
</head> 
<meta http-equiv="refresh" content="2; url=18-2.php"> 
<body> 
登录 成 功 ! <p> 
两 秒 后 进入 管理 页 。 
</body> 
</html> 
<? 
下 


?> 

把 以 上 代码 保存 为 “18-3.php”， 以 备 后 用 。 

该 文件 没有 什么 技术 含量 ， 只 是 进行 了 简单 的 判断 。 并 根据 不 同 的 结果 跳 转 到 不 到 的 页 面 。 如 果 
密码 正确 ， 则 把 信息 写 入 Cookie 数据 。 


18.4.4 修改 留言 页 面 的 创建 


如 果 留 言 中 出 现 了 不 合适 的 内 容 ， 应 修改 它们 。 这 时 就 需要 修改 留言 页 面 出 场 了 。 修 改 留言 的 实 
质 是 读 出 某 一 条 留言 ， 读 出 其 中 的 内 容 ， 用 新 内 容 代替 原 有 内 容 ， 其 实质 还 是 对 文件 的 操作 。 
下 面 就 来 创建 修改 留言 页 面 : 
<? 
require "18-1.php"; 
if(!$_POST[content]) // 如 果 没有 提交 ID 
if(!$_GET[id]) // 如 果 没 有 指定 修改 ID 


echo "没有 指定 ID"; 
exit(); 
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$id=$_GET["id"]; // 把 参数 ID 赋值 给 变量 
$myfile=file($file_name); INER file() 函 数 把 文件 按 行 读 入 到 数组 
$z=$myfile[0]; // 数 组 第 一 个 元 素 赋 值 给 变量 
S$temp=explode("||",$myfile[$z-$id]); // 使 用 explode 分 割 相 应 记录 到 数组 

?> 

<html> 

<head> 

<title> 文 本 留言 板 一 一 修改 留言 </title> 

</head> 

<body> 

<center> 

<h1> 文 本 留言 板 一 一 修改 留言 </h1> 

<p> 

<h3> 只 有 留言 主题 与 留言 内 容 是 可 以 改变 的 </h3> 

<p> 

<a href=18-2.php> 返 回首 页 </a> 

<table border=1> 

<form method="post" action=<?echo $PATH_INFO?>> 

<inputtype=hidden value=<?echo $temp[0]?> name=id> 

<tr> 

<td colspan="2"> 以 下 为 第 <?echo $temp[0]?> 条 留言 的 内 容 </td> 

</tr> 

<tr> 

<td>: </td> 

<td><?echo $temp[1]?></td> 

</tr> 

<tr> 

<td> 主 题 ，</td> 

<td><input name="subject" type="text" value=<?echo $temp[2]?>></td> 

</tr> 

<tr> 

<td colspan="2"> 内 容 : </td> 

</tr> 

<tr> 

<td colspan="2"> 

<textarea name="content" cols="36" rows="8"><?echo $temp[3]?></textarea> 

</td> 

</tr> 

<tr> 

<td colspan="2"> 

<input type="submit" name="Submit" value=" 确 定 "> 

<input type="reset" name="Submit2" value=" 清 除 "> 

</td> 

</tr> 

</form> 

</table> 

</center> 

</body> 

</html> 
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<? 

} 

else 
$id=$_POST[id]; /定义 ID 
$subject=$_POST[subject]; 
$content=$_POSTI[content]; /定义 内 容 
$myfile-file($file name); // 使 用 file() 函 数 把 文件 按 行 读 入 到 数组 
$z=$myfile[0]; // 数 组 第 一 个 元 素 赋值 给 变量 
S$temp=explode("||",$myfile[$z-$id]); // 使 用 explode 分 割 相应 记录 到 数组 
$s=$temp[0]."]|".$temp[1]."]|".$subject."]|".$content."]|".§temp[4]; 
for($i=0;$i<($z-$id);$i++) 
{ 

Ş$text2=$text2.$myfile[$i]; // 内 容 保持 不 变 
} 
for($i=($z-$id+1);$i<$z;$i++) // 新 欲 删除 的 后 一 条 记录 到 最 后 一 条 记录 
{ 
$text1=$text1.$myfile[$i]; // 内 容 保持 不 变 

} 
$fp=fopen($file_name,"w"); MASHIA OHARA E) 
fwrite($fp,$text2); // 写 入 欲 删除 记录 之 前 的 所 有 记录 
fwrite($fp,$s); // 写 入 更 改过 的 记录 
fwrite($fp, $text1); // 写 入 欲 删除 记录 之 后 的 所 有 记录 
fclose($fp); // 关 闭 文件 

?> 

<html> 

<head> 

<title> 文 本 留言 板 一 一 修改 留言 </title> 

</head> 

<meta http-equiv="refresh" content="2; url=18-2.php"> 

<body> 

修改 成 功 ! <p> 

两 秒 后 返回 。 

</body> 

</html> 

<? 

} 

?> 


将 以 上 代码 保存 为 “18-4.php”， 以 备 后 用 。 
以 上 代码 ， 实 现 了 对 文本 文档 的 复杂 操作 。 不 过 从 以 上 代码 可 以 发 现 ， 文 本 留言 板 相当 低 效 。 为 
了 修改 一 条 留言 , 就 不 得 不 把 所 有 留言 内 容 读 入 内 存 。 不 过 好 在 现在 连 最 一 般 的 PC 机 处 理 数据 的 速度 
也 是 相当 快 的 ， 所 以 使 用 文本 留言 板 的 速度 瓶颈 并 不 是 特别 明显 。 


18.4.5 删除 留言 页 面 的 创建 


网 上 的 所 有 留言 板 都 面临 着 一 个 问题 的 困扰 ， 那 就 是 “恶意 灌水 ”。 对 那些 恶意 灌水 的 留言 记录 ， 
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要 及 时 删除 。 这 样 一 方面 可 以 减少 空间 的 占用 ， 另 外 还 可 以 使 整个 留言 本 页 面 显 得 干净 整洁 。 
这 一 小 节 就 来 创建 删除 留言 页 面 。 具 体内 容 参 考 以 下 代码 : 
<? 


require "18-1.php"; 
if(!$_GETI[id]) // 如 果 没 有 指定 删除 ID 


echo "没有 指定 ID"; 
exit(); 


$id=$_GETI"id"]; // 把 参数 ID 赋值 给 变量 
$myfile=file($file_name); /使 用 file() 函 数 把 文件 按 行 读 入 到 数组 
$z=$myfile[0]; /人 数组 第 一 个 元 素 赋值 给 变量 
S$temp=explode("||",$myfile[$z-$id]); INER explode 分 割 相应 记录 到 数组 
for($i=0;$i<($z-$id);$i++) 
{ 
$temp2=explode("||",$myfile[$i]); /使 用 explode 分 割 相应 记录 到 数组 
$temp2[0]--; /记录 号 实现 自 减 
$text2=$text2.$temp2[0]."||".$temp2[1]."||". $temp2[2]."||".$temp2[3]."||".$temp2[4]; 
// 把 新 的 内 容 赋值 到 变量 
} 
for($i=($z-$id+1);$i<$z;$i++) /新 欲 删除 的 后 一 条 记录 到 最 后 一 条 记录 
$text1=$text1.$myfile[$i]; /内容 保持 不 变 
} 
$fp=fopen($file_name,"w"); /以 写 入 方式 打开 文件 〈 文 件 同时 被 清空 ) 
fwrite($fp, $text2); // 写 入 欲 删 除 记录 之 前 的 所 有 记录 
fwrite($fp, $text1); // 写 入 欲 删 除 记录 之 后 的 所 有 记录 
fclose($fp); /| 关闭 文件 
?> 
<html> 
<head> 
<title> 文 本 留言 板 一 一 删除 留言 </title> 
</head> 
<meta http-equiv="refresh" content="2; url=18-2.php"> 
<body> 
删除 成 功 ! <p> 
两 秒 后 返回 。 
</body> 
</html> 


把 以 上 代码 保存 为 “18-5.php”， 以 备 后 月 

该 文件 的 实现 方法 是 先 读 出 欲 删除 留言 记录 之 前 的 所 有 记录 , 并 把 它们 的 记录 号 全 部 自 减 1。 再 读 
出 欲 删 除 留言 记录 后 的 所 有 记录 ， 保 持 不 变 。 然 后 ， 再 把 修改 过 的 记录 全 部 写 入 文件 ， 这 样 原 有 的 欲 
删除 的 记录 就 会 被 从 文件 中 “删除 ”， 实 质 上 是 重新 写 入 了 不 被 删除 的 文件 。 

至 此 ， 该 文本 留言 板 的 所 有 页 面 就 全 部 完成 了 。18.5 节 将 对 该 系统 做 一 下 测试 ， 测 试 该 文本 留言 
板 各 项 功能 是 否 都 能 正常 运行 。 
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18.5 调试 运行 留言 板 


18.4 节 ， 已 经 把 留言 板 所 需 的 模块 全 部 创建 完毕 ， 这 一 节 就 对 留言 板 做 全 面 测 试 。 

(1) 先 在 PHP 执行 环境 下 运行 18-2.php。 由 于 是 第 1 次 运行 ， 所 以 结果 会 如 图 18.1 所 示 。 由 于 
此 时 还 没有 任何 留言 ， 所 以 显示 记录 条 数 为 0。 到 18-2.php 所 在 的 路 径 下 查看 会 发 现 多 了 一 个 名 为 
“data.dat” 的 空 文件 。 说 明 创 建 数据 文件 成 功 。 单 击 “ 签 写 留言 ”链接 来 测试 插入 记录 功能 是 否 正常 。 
单 击 链接 后 ， 在 页 面 下 方 会 出 现 输入 表单 ， 如 图 18.2 所 示 。 


四 文 直 留言 板 WRENN -sicrexwft Taterasi TEI 
ET | & 
ZSEE EDN E| 
自前 沁 录 条 数 为 ，0 
了 清 输入 留言 内 容 
LHD RBV FEV KEV IRV HMV CZT [ 
ER ; = E 
文本 留言 板 一 一 记录 显示 页 Em 
签 写 留言 管理 入 口 H 
目前 记录 条 数 为 ,0 
第 一 页 | 上 一 页 | 下 一 页 | 最 后 一 页 | 图 
zi ai ani ai zi 
EEEN CESSI gi O] CUT T Oie ya 
图 18.1 第 1 次 执行 显示 留言 页 执行 结果 图 18.2 显示 隐藏 的 表单 效果 
(2) 在 如 图 18.2 所 示 的 表单 中 输入 相应 的 内 容 ， 然 后 单 击 “ 确 定 ”按钮 ， 会 出 现 如 图 18.3 所 示 
的 结果 。 


G) 留言 添加 成 功 后 ， 直 接 跳 转 回来 。 从 图 18.3 可 以 看 出 ， 留 言 已 经 成 功 添加 并 显示 ， 打 开 留 言 
板 程 序 目录 下 的 data.dat 文件 ， 其 中 内 容 如 下 所 示 。 
州 无 名 氏 || 今 天 天 气 不 错 || 今 天 天 气 不 错 ， 不 太 冷 也 不 太 热 。||2006 年 10 月 05 日 


可 见 ， 已 经 将 相关 信息 正确 添加 至 记录 文件 了 。 


文本 留言 板 一 一 记录 显示 页 ” 
签 写 留言 管理 入 口 


共有 1 条 内 容 。 分 1 页 显示 “当前 显示 第 1 页 
EES. 无 名 民 写 于 2006 年 10 月 0 日 | 
STE 


谷 天 天 气 不 错 ， 不 太 冷 也 不 太 热 
第 -页 | 上 一 页 | 下 一 页 | B-T 


I Ome 


I Er 


图 18.3 添加 留言 执行 结果 图 18.4 管理 留言 板 执行 结果 


A 


(5) 输入 正确 的 密码 (这 里 输入 前 面 18-1.php 中 定义 的 $super_pass KE) ， 并 单 击 “ 登 录 ” 按 钮 
后 ， 结 果 会 如 图 18.5 所 示 。 对 比 图 18.3 与 图 18.5 的 区 别 ， 可 以 发 现 ， 图 18.5 比 图 18.3 上 每 一 条 留言 
后 面 都 多 了 修改 与 删除 的 链接 。 说 明 已 经 正常 登录 并 可 以 进行 相关 操作 。 

(6) 由 于 现在 留言 板 中 记录 较 少 ， 所 以 继续 添加 一 些 记录 ， 以 测试 相关 内 容 。 单 击 图 18.5 中 的 修 
改 链接 ， 将 打开 如 图 18.6 所 示 的 画面 。 


文本 留言 板 一 一 修改 留言 
入 文本 售 言 板 一 记录 旦 示 页 - Micrsoft Internet Kaplerer i we 
TE O TETA C 只 有 留言 主题 与 留言 内 容 是 可 以 改变 的 
Er $ = = 返回 首页 
文本 留言 板 一 一 记录 显示 页 TISANE | 
隆 名 ， AER 
签 写 留言 管理 入 品 Sa 
共有 1 条 内 容 。 分 1 页 显示 。 当前 显示 第 1 页 BE O | 
利 1 条 留言 作者， 无 名 氏 | 写 于 2006 年 10 月 05 日 修改 HE ARUME, KA R: z 
主题 ， 今 天 天 气 不 异 
AE 
今天 天 气 不 悄 ， 不 太 冷 也 不 大 热 。 
p -N | 下 -页 | 最 后 一 
第 一 页 | 上 一 页 | 下 一 页 | 最 后 一 页 F Loo E] S 
CO T Eie | [OEA LIA AA KA E Al 
图 18.5 正确 登录 管理 执行 结果 图 18.6 修改 记录 的 前 台 


(7) 按照 需要 进行 修改 ， 这 里 把 “今天 天 气 不 错 ”， 改 为 “今天 天 气 为 什么 这 么 不 错 ? ”， 其 他 
的 内 容 保持 不 变 ， 单 击 下 方 的 “确定 ”按钮 。 执 行 结果 如 图 18.7 所 示 。 从 图 18.7 的 执行 结果 可 以 看 出 
留言 内 容 已 经 按照 用 户 的 输入 进行 了 更 改 ， 说 明 修改 留言 功能 运行 正常 。 
(8) 下 面 测试 程序 的 删除 功能 。 删 除 前 的 记录 情况 如 图 18.8 所 示 。 


文本 留言 板 一 记录 显示 页 
文本 留言 板 记录 显示 页 | zasa aa 
J 


文件 中 MD HEV KRV IRAD WHW | 


共有 2 第 内 容 。 分 1 页 显示 。 当前 显示 第 1 页 
重 2 条 留言 作者 ， 天 下 征 一 | 写 于 2006 年 10 月 05 日 修改 ， 抽 除 
主题 ,为 什么 会 这 样 


AF: 
因为 我 是 天 下 第 一 ! 


便 ! 季 留言 作者， 元 名 氏 ” | 写 于 2006 年 10 月 05 日 PA ME 
| 主题， 今天 天 气 为 什么 这 么 不 错 1 


签 写 留言 管理 入 


共有 1 条 内 容 。 分 1 页 显示 。 “当前 显示 第 页 
| 第 1 条 留言 作者 , 无 名 氏 | 写 于 2006 年 10 月 05 日 修改 ME 
主题 ， 今 天 天 气 为 什么 这 么 不 错 ? 


AE: 
| 今天 天 气 不 错 ， 不 太 冷 也 不 太 热 。 


RE: 
S-A | L-R | 下 -页 | RS-A 今天 天 气 不 悄 ， 不 太 冷 也 不 太 热 。 m 


第 一 页 | 上 一 页 | 下 一 页 | 景 后 一 页 zi 
PEJ COO Om EE el el EE zA 
18.7 ”修改 后 的 结果 18.8 ”删除 操作 前 的 效果 


(9) 下 面 把 图 18.8 中 的 第 2 条 留言 删除 。 单 击 “ 删 除 ”链接 执行 18-5.php。 执 行 后 的 结果 如 
图 18.9 所 示 。 

(10) 对 比 图 18.8 与 图 18.9 可 以 发 现 : 留言 数量 由 原来 的 2 条 变 成 了 1 条 ， 有 一 条 信息 已 经 被 删 
除 。 至 此 整个 系统 全 部 测试 完毕 。 
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BAE - Microsoft Interet Erplaren 
XFO SBV STO MBW IAV EMW 


文本 留言 板 一 一 记录 显示 页 


签 写 留言 管理 入 品 
共有 1 条 内 容 。 分 1 页 显示 。 “当前 显示 第 1 页 
ERUS 作者 ,无 名 氏 | 写 于 2006 年 10 月 05 日 pA ME 
EE: 今天 天 气 为 什么 这 么 不 错 ? 


Wa 
| 今天 天 气 不 错 ， 不 太 冷 也 不 术 热 


第 一 页 | 上 一 页 | 下 一 页 | 最 后 一 页 国 
[Ea TT 4] 


图 18.9 删除 操作 后 的 结果 


18.6 ”进一步 完善 


这 个 文本 留言 板 对 于 个 人 用 户 来 说 基本 上 已 经 够 使 用 了 。 不 过 ， 如 果 对 要 求 比较 多 的 用 户 来 说 ， 
该 留言 板 还 是 有 需要 完善 的 地 方 。 其 一 ， 留 言 板 没有 回复 功能 。 其 二 ， 留 言 板 存在 安全 隐患 。 其 三 ， 
留言 板 的 内 容 还 不 够 丰富 ， 如 提交 留言 时 没有 可 以 使 用 表情 图 片 之 类 的 功能 。 

对 于 这 些 问 题 ， 作 者 只 提供 解决 思路 ， 有 兴趣 的 读者 ， 可 以 自行 研究 以 丰富 这 个 文本 留言 板 。 

对 于 第 1 个 问题 ， 留 言 板 没 有 回复 功能 ， 解 决 起 来 相对 麻烦 一 些 ， 可 以 给 留言 数据 在 原来 的 5 项 ， 
留言 ID、 作 者 、 题 目 、 内 容 、 留 言 时 间 上 再 增加 一 项 r id。 该 项 只 记录 父 留言 的 ID， 如 果 某 一 条 留言 
本 身 就 是 父 留 言 ， 则 rid 的 值 为 0。 然 后 在 显示 一 条 编号 为 ID 的 留言 时 ， 再 遍历 它 后 面 所 有 r_id= 父 
留言 ID 的 记录 作为 回复 显示 。 这 样 就 可 以 了 ， 虽 然 这 样 能 够 实现 ， 但 在 删除 留言 特别 是 父 留言 时 就 会 
相当 麻烦 。 这 也 是 文本 留言 板 自身 的 一 个 局 限 性 。 

现在 这 个 留言 板 有 什么 安全 隐患 呢 ? 因为 没有 对 用 户 的 输入 进行 相应 的 屏蔽 ， 所 以 用 户 可 以 使 用 
HTML 代码 。 这 在 通常 情况 下 是 不 被 允许 的 。 不 过 解决 起 来 很 简单 ， 就 是 使 用 htmlspecialchars() 函 数 对 
用 户 的 输入 做 相应 的 处 理 。 这 样 输入 的 HTML 代码 就 会 被 变 成 普通 的 文本 ， 不 再 具有 威胁 性 了 。 

添加 表情 ， 也 不 复杂 ， 只 需 给 原来 的 数据 上 再 增加 一 项 ， 里 面 存放 小 图 片 的 链接 。 显 示 时 ， 显 示 
相应 的 表情 符号 或 者 小 图 片 即 可 。 


18.7 KË b% 


至 此 ， 关 于 文本 留言 板 的 内 容 就 全 部 为 读者 介绍 完了 。 虽 然 文 本 留言 板 有 其 局 限 性 ， 功 能 上 还 不 
够 强大 ， 但 只 要 善于 通过 不 同 的 方法 去 解决 现实 问题 ， 文 本 留言 板 还 是 有 用 武之 地 的 。 通 过 本 章 的 学 
习 ， 相 信 读 者 对 于 如 何 建立 并 使 用 一 个 文本 留言 板 都 应 该 有 一 个 深刻 的 认识 了 。 说 到 底 ， 文 本 留言 板 
其 实质 还 是 对 文本 文件 的 操作 。 这 一 章 就 为 读者 介绍 到 这 里 。 
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如 果 要 问 当前 网 络 上 最 流行 的 网 络 应 用 是 什么 , 真正 的 答案 是 博客 。 关 于 博客 的 说 
法 和 上 比喻 ， 网 上 有 这 样 几 种 : 1、 博 客 是 继 E-mail、BBS5、ICQ 之 后 出 现 的 第 4 种 网 络 交 
AFN. 2. 博客 是 网 络 时 代 的 个 人 “读者 文摘 ”。3.、 博客 是 以 超级 链接 为 武器 的 网 
络 日 记 。4.、 博客 是 信息 时 代 的 麦哲伦 。5.、 博客 代表 着 新 的 生活 方式 和 新 的 工作 方式 ， 
更 代表 着 新 的 学 习 方 式 。 通 过 博客 ， 让 自己 学 到 很 多 ， 让 别人 学 到 更 多 。6、 博 客 代表 
着 “新 闻 媒 体 3.0 版 ”， 旧 媒体 【Old Media) 一 新 媒体 【New Media) 一 自 媒 体 (We 
Media) 。 


总 之 ,博客 是 一 个 正 处 于 快速 发 展 和 快速 演变 中 的 互联 网 新 应 用 。 所 以 ， 对 于 一 个 
PHPer (PHP 程序 员 ) 来 说 ， 了 解 如 何 写 出 高 效 的 博客 程序 是 十 分 有 必要 的 。 这 一 章 就 
向 读者 介绍 一 下 如 何 用 PHP 和 MySQL 数据 库 结 合 来 制作 一 个 简单 的 博客 程序 。 本 章 
内 容 包括 什么 是 博客 、 简 单 的 博客 程序 的 功能 、 博 客 程序 的 代码 实现 等 。 通 过 本 章 的 学 
习 ， 会 使 读者 对 什么 是 博客 、 如 何 写 出 博客 程序 有 本 质 上 的 认识 。 
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19.1 什么 是 博客 


要 想 写 出 博客 程序 ， 第 1 步 就 是 要 先 搞 明白 ， 到 底 什么 是 博客 ， 这 一 节 就 来 回答 这 个 问题 。 

中 文 “博客 ”一 词 ， 源 于 英文 单词 Blog/Blogger。Blog 是 Weblog 的 简称 。Weblog 其 实 是 We 和 
Log 的 组 合 词 。Web 指 World Wide Web， 当 然 是 指 互联 网 了 ; Log 的 原 义 则 是 “航海 日 志 ”， 后 指 任 
何 类 型 的 流水 记录 。 合 在 一 起 理解 ，Weblog 就 是 在 网 络 上 的 一 种 流水 记录 形式 或 者 简称 “网 络 日 志 ”。 

Blogger 或 Weblogger 是 指 习 惯 于 日 常 记录 并 使 用 Weblog 工具 的 人 。 虽 然 在 大 陆 早 些 时 候 或 者 在 
我 国 台湾 等 地 ， 对 此 概念 的 译名 不 尽 相 同 (有 的 称 为 “网 志 ”， 有 的 称 之 为 “网 录 ” 等 ) ， 但 目前 已 
基本 统一 到 “博客 ”一 词 上 来 。 该 词 最 早 是 在 2002 年 8 月 8 日 由 著名 的 网 络 评论 家 王 俊秀 和 方兴东 共 
同 撰文 提出 来 的 。 博 客 也 好 ， 网 志 也 罢 ， 仅 仅 是 一 种 名 称 而 已 ， 它 的 本 义 还 是 逃 不 过 Weblog 的 范围 。 
只 是 ， 通 常 所 说 的 “博客 ”， 既 可 用 作为 名 词 Blogger 或 weblogger 一 一 指 具 有 博客 行为 的 一 类 人 ; 也 
可 以 作 动词 用 〈 相 当 于 英文 中 的 Weblog EÈ blog) ， 指 博客 采取 的 具有 博客 行为 反映 、 是 第 三 方 可 以 用 
视觉 感受 到 的 行为 ， 即 博客 们 所 撰写 的 Blogs Ke, “他 /她 是 一 位 博客 ， 他 /她 天 天 在 博客 ”及 “博客 
博 什 么 客 ?” 在 中 文 语法 与 逻辑 上 都 是 正确 的 。 只 是 不 同 场合 的 用 法 不 同 罢了 。 

Blog 究 竞 是 什么 ? 说 了 半天 ， 其 实 一 个 Blog 就 是 一 个 网 页 ， 它 通常 是 由 简短 且 经 常 更 新 的 帖子 
(Post) 所 构成 ， 这 些 张 贴 的 文章 都 按照 年 份 和 日 期 倒序 排列 。Blog 的 内 容 和 目的 有 很 大 的 不 同 ， 从 
对 其 他 网 站 的 链接 、 评 论 ， 有 关公 司 、 个 人 构想 的 新 闻 ， 到 上 日记、 照片 、 诗 歌 、 散 文 ， 甚 至 科幻 小 说 的 
发 表 或 张贴 都 有 。 许 多 Blogs 只 是 记录 着 blog 个 人 所 见 、 所 闻 、 所 想 ， 还 有 一 些 Blogs 则 是 一 群 人 基于 
某 个 特定 主题 或 共同 利益 领域 的 集体 创作 。 撰 写 这 些 Weblog 或 Blog 的 人 就 叫做 Blogger 或 Blog writers 
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19.1 节 为 读者 介绍 了 什么 是 博客 。 这 一 节 ， 就 接着 来 讲 ， 简 单 博客 程序 所 应 具有 的 功能 。 

通常 一 个 最 简单 的 博客 程序 应 具有 以 下 功能 : 

口 博客 所 有 者 可 以 添加 日 志 。 

O 普通 浏览 者 无 权 添加 日 志 ， 只 能 对 已 经 存在 的 内 容 进行 评论 。 

O ”所 有 者 可 以 管理 日 志 。 内 容 包括 删除 、 编 辑 日 志 ; 增加 、 删 除 更 改 日 志 的 类 别 等 ， 以 及 可 以 
设 定 日 志 的 保密 状态 ， 注 册 用 户 与 普 能 用 户 的 权限 等 。 

O ”通常 情况 下 ， 日 志 还 附带 一 个 留言 板 ， 供 普通 浏览 者 与 博客 的 所 有 者 进行 有 效 的 交流 。 

o “可 以 用 一 个 简单 的 用 户 注册 、 登 录 系 统 ， 以 使 普通 浏览 者 与 注册 用 户 有 不 同 的 权限 。 


193 ”制作 前 的 准备 工作 


通过 19.1 节 和 19.2 节 的 介绍 , 读者 对 于 什么 是 博客 程序 ,一 个 简单 的 博客 程序 所 应 具备 的 功能 应 
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该 有 一 个 大 致 的 认识 了 。 从 这 一 节 开始 , 就 来 通过 PHP 代码 来 一 步 步 实现 简单 的 博客 程序 的 所 有 功能 。 


19.3.1 


配置 文件 是 程序 各 种 资源 访问 的 源头 


配置 文件 的 创建 


户 名 、 密 码 、 数 据 库 名 、 表 名 等 重要 信息 。 
具体 内 容 参看 以 下 代码 : 


<? 


$host="localhost"; 
$user="root"; 

$pass=""; 
$db_name="test"; 
$table_log="b_log"; 
$table_user="b_user"; 
$table_gbook="b_gbook"; 
$table_sort="b_sort"; 


?> 


。 其 中 存放 着 连接 博客 程序 数据 库 的 主机 名 、 连 接 主机 的 用 


// 主 机 名 
/用户 名 
/密码 
/数据 库 名 
NAER 
IAPR 
// 留 言 表 
IZAR 


把 以 上 代码 保存 为 “19-1.php”， 以 备 后 用 。 


19.3.2 安装 文件 的 创建 


这 一 小 节 ， 来 创建 一 个 安装 文件 。 该 文件 的 作用 是 从 配置 文件 〈19-1.php) 中 获取 基本 信息 ， 然 后 
提供 给 用 户 一 个 表单 。 当 用 户 按 要 求 填写 所 需 数据 后 ， 执 行 创建 表 及 插入 记录 的 操作 ， 完 成 程序 表 的 


创建 。 


下 面 给 出 具体 的 代码 : 


<? 


if(!$_POST[admin]) 


{ 


echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 安 装 程序 </title>\n"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "<script language=\"javascript\">\n"; 
echo "function juge(theForm)\n"; 

echo "An"; 

echo "\tif (theForm.admin.value == \"\")\n"; 
echo "Win"; 

echo "t\talert(\" 请 输入 管理 员 名 称 ! \");\n"; 
echo "t\ttheForm.admin.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "tin"; 

echo "\tif (theForm.pass.value == \\")\n"; 


// 如 果 没 有 默认 参数 ， 则 显示 HTML 


.354 。 
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echo ”tfn ; 

echo "titalert(\" 请 输入 管理 员 密 码 ! \")\n"; 

echo "\t\ttheForm.pass.focus();\n"; 

echo "Wtreturn (false);\n"; 

echo "itn"; 

echo "\tif (theForm.pass.value.length < 8 )\n"; 

echo "Win"; 

echo "\ttalert(" EBEDE 8 fù! \");\n"; 

echo "\tittheForm.pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "An"; 

echo "if (theForm.re_pass.value !=theForm.pass.value)\n"; 

echo "Win"; 

echo "titalert(\" 确 认 密 码 与 密码 不 一 致 ! \");\n"; 

echo "\t\ttheForm.re_pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "tAn"; 

echo "\tif (theForm.nickname.value == \"\")\n"; 

echo "Wan"; 

echo "tltalert(\" 请 输入 昵称 !\");\n"; 

echo "\t\ittheForm.nickname.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo wwthn"; 

echo "An"; 

echo "</script>\n"; 

echo "<center>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\" align=\"center\" bgcolor=\"#000000\">\n"; 
echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)\">\n"; 
echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 安 装 博客 </font></td>\n"; 
echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td> 管 理 员 : HABAR) </td>\n"; 

echo "<td><input type=\"text\" name=\"admin\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td> 管 理 员 密码 : 〈 不 小 于 8 位 ) </td>\n"; 

echo "<td><input type=\"password\" name=\"pass\" size=\"21\"></td>\n"; 
echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td> 确 认 密码 : </td>\n"; 

echo "<td><input type=\"password\" name=\"re_pass\" size=\"21\"></td>\n"; 
echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td> 管 理 员 E-mail: (可 选 )</td>\n"; 

echo "<td><input type=\"text\" name=\"email\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td> 管 理 员 昵称 : (MAFF) </td>\n"; 


else 
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echo "<td><input type=\"text\" name=\"nickname\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td colspan=\"2\"><center><input type=\"submit\" value=\" 下 一 步 \"*></center></td>\n"; 
echo "</tr>\n"; 
echo "</form>\n"; 
echo "</table>\n"; 
echo "</center>\n" 


echo "</body>\n"; 
echo "<html>\n"; 

// 如 果 有 POST 参数 执行 操作 
$username=$_POST[admin]; // 获 得 参数 


$password=md5($_POST[pass]); 
$nickname=$_POST[nickname]; 
$email=$_POST[email]; 
require "19-1.php"; 
S$link=mysql_connect("$host","$user","$pass") or die(mysql_error()); 
mysg| select db($db name,$link); // 选 择 数据 库 
$sql="create table $table_log( 
id int(5) not null auto_increment primary key, 
_id int(5) not null default 0, 
title varchar(40) not null default ", 
content text not null default ", 
sort varchar(20) not null default", 
views int(5) not null default 0, 
tbcount int(5) not null default 0, 
author varchar(40) not null default", 
date varchar(20) not null default ", 
top enum('n','y') not null default 'n', 
hide enum(n',y') not null default 'n', 
allow_tb enum(n',y') not null default 'n' 
yA 
mysql_query($sql,$link) or die(mysql_error()); /发 送 创建 B_ LOG 表 的 SQL 请 求 
$sql="create table $table_user( 
id int(5) not null auto_increment primary key, 
username varchar(40) not null default ", 
password varchar(40) not null default", 
admin enum('1','0') not null default 'O', 
nickname varchar(20) not null default ", 
sex enum('boy','girl') not null default 'boy', 
photo varchar(80) not null default ", 
email varchar(60) not null default ", 
description varchar(200) not null default " 
y" 
mysql_query($sql,$link) or die(mysql_error()); /发 送 创建 B_USER 表 的 SQL 请 求 
$sql="create table $table gbook( 
id int(5) not null auto_increment primary key, 
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title varchar(40) not null default ", 

content text not null default ", 

author varchar(40) not null default", 

date varchar(30) not null default " 

六 

mysql_query($sql,$link) or die(mysql_error()); /发 送 创建 B _GBOOK 表 的 SQL 请 求 

$sql="create table $table sort( 

id int(5) not null auto increment primary key, 

sortname varchar(20) not null default ", 

sortimg varchar(60) not null default", 

sortnum int(5) not null default 0, 

description varchar(200) not null default " 

r: 

mysql_query($sql,$link) or die(mysql_error()); /发 送 创建 B SORT 表 的 SQL 请 求 

$sql="insert into $table_sort(sortname,sortimg,description)values(' 默 认 类 别 ,images\vsort.img', 默 认 的 分 
类 ， 请 更 改 ! )"; 

mysql_query($sql,$link) or die(mysql_error()); /发 送 添加 默认 分 类 的 SQL 请 求 

$sql="insert into 
$table user(username,password,admin,nickname,email,description)values('Susemame','$password','1','$nickn 
ame',$email, 我 就 是 本 小 站 的 管理 员 ! ')"; 

mysql_query($sql,$link) or die(mysql_error()); /发 送 添加 管理 员 信 息 的 SQL 请 求 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 安 装 程序 </title>\n"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "</center>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\" align=\"center\" bgcolor=\"#000000\">\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td align=\"center\"><font size=\"5px\"> 安 装 博 客 </font></td>\n"; 

echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td align=\"center\"><font size=\"3px\"> 成 功 安装 ! </font></td>\n"; 

echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td align=\"center\"> <a href=\"19-5.php\"> 这 里 </a> 进 入 </td>\n"; 

echo "</tr>\n"; 


echo "</table>\n"; 
echo "</center>"; 
echo "</body>\n"; 
echo "</html>\n"; 
} 
?> 


把 以 上 代码 保存 为 “19-2.php”， 然 后 在 PHP 执行 环境 下 运行 该 PHP 文件 ， 以 完成 各 种 所 需要 的 
表 的 创建 。 其 首次 执行 结果 如 图 19.1 所 示 。 按 图 19.1 的 要 求 填 入 用 户 信息 ， 然 后 单 击 “ 下 一 步 ” 按钮 ， 
将 会 开始 各 种 表 的 创建 工作 。 进 度 完成 之 后 的 结果 如 图 19.2 所 示 。 
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这 时 各 种 表 已 经 创建 完成 了 。 可 以 登录 进去 体验 一 下 博客 的 魅力 了 ， 但 是 现在 还 不 能 单 击 “ 点 这 
里 进入 ”链接 ， 因 为 相关 的 页 面 还 没有 被 创建 。 下 一 步 ， 就 来 创建 登录 的 页 面 。 


19.3.3 ” 头 文件 的 创建 


头 文件 ， 显 示 页 面 的 头 部 分 。 单 独 做 成 一 个 文件 ， 便 于 在 多 处 调用 ， 以 减少 代码 的 体积 。 有 具体 内 
容 参 看 以 下 代码 : 


<? 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 博 客 程序 </title>\n"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "<style type=\"text/css\">"; 

echo "p{ font-size: 12px; color:#0000ff}"; 

echo "table { table-layout: fixed; word-wrap:break-word;}"; 

echo "td {text-align: left; text-valign:center; font-size: 12px;}"; 

echo "body { font-size: 12px; text-decoration: none;color:#3300cc}"; 

echo "a{ font-size: 12px; text-decoration: none; color: #0000FF}"; 

echo "a:hover { color: #FF0000; text-decoration: underline}"; 

echo "a:link { text-decoration: none}"; 

echo "</style>"; 

echo "<center>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\" align=\"center\" bgcolor=\"#000000\">\n"; 
echo "<tr>\n"; 

echo "<td bgcolor=\"#fffffì\"></td>\n"; 

echo "<td bgcolor=\"#cccc99\"><center><a href=\"19-5.php\"> 首 页 </a></center></td>\n"; 
echo "<td bgcolor=\"#cccc99\"><center><a href=\"19-6.phpW"> 日 志 </a></center></td>\n"; 
echo "<td bgcolor=\"#cccc99\"><center><a href=\"19-17.php\"> 留 言 </a></center></td>\n"; 
echo "<td bgcolor=\"#cccc99\"><center><a href=\"19-8.php\"> 管 理 </a></center></td>\n"; 
echo "</tr>\n"; 

echo "</table>\n"; 

echo "<p>"; 

?> 
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把 以 上 代码 保存 为 “19-3.php” 备 用 ， 以 便 其 他 页 面 能 够 调用 该 文件 ， 以 减少 代码 量 。 


19.3.4” 侧 边 文件 的 创建 


通常 的 博客 程序 侧 边 显示 的 内 容 也 是 基本 相同 的 ,与 头 文件 一 样 , 侧 边 也 可 以 单独 做 成 一 个 文件 ， 
需要 时 调用 即 可 。 这 样 做 的 好 处 显而易见 ， 如 减少 代码 量 ， 减 轻 程序 更 改 工作 量 。 如 果 需 要 对 某 一 部 
分 进行 修改 ， 直 接 修改 该 文件 即 可 ， 而 不 用 一 个 页 面 文件 一 个 页 面 文件 的 修改 。 侧 边 显示 以 下 内 容 : 


口 博客 管理 员 信息 。 

口 用 户 登录 表单 。 

O ”如 果 用 户 已 经 登录 则 显示 登录 用 户 名 称 。 

口 日 历 ， 以 便 使 用 者 可 以 根据 不 同日 期 查看 当天 的 日 志 。 

口 日 志 的 所 有 类 别 。 方便 使 用 者 选择 不 同 的 类 别 。 

具体 内 容 参 看 以 下 代码 : 

<? 

echo "<table cellpadding=\"1\" cellspacing=\"1\" align=\"centen\" bgcolor=\"#000000\">\n"; 
echo "<tr>"; 

echo "<td bgcolor=\"#eeeeff\">"; 

require "19-1.php"; // 调 用 配置 文件 
$link=mysql_connect($host$user,$pass); // 连 接 主 机 
mysql_select_db($db_name,$link); // 选 择 数 据 库 
$sql="select * from $table user where admin="1"; /显示 管理 员 信息 
$result=mysql_query($sql,$link); /发 送 SQL 请 求 
$row=mysql_fetch_array($result); // 获 取信 息 

echo "管理 员 昵 称 : "; 

echo $row[nickname]; /显示 昵称 
echo "<br>"; 

echo "管理 员 性 别 : "; 

echo $row[sex]; /显示 性 别 

echo "<br>"; 

echo "管理 员 信箱 :"; 

echo $row[email]; /显示 信箱 
echo "<br>"; 


echo "管理 员 图 像 : "; 

if($row[photo]) echo "<img src=images/".$row[photo].">"; // 如 果 有 图 像 ， 则 显示 图 像 
echo "<br>"; 

echo "管理 员 自白 :<br>"; 

echo $row[description]; /显示 自白 

echo "</td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td bgcolor=\"#eeeeff\">"; 

if(!$_COOKIE[usemame]) // 如 果 没有 登录 用 户 
{ 

echo "<form action=19-8.php method=post>"; /显示 登录 表单 
echo "用 户 名 : <input type=text name=usemame size=5><br>"; 
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echo "密码 : <input type=password name=password size=6><br>"; 

echo "<input type=submit value=\" 登 录 \">"; 

echo "<input type=button value=\" 注 册 \" onclick=w_open()>"; 

echo "</form>"; 

} 

else // 如 果 有 登录 用 户 
{ 

echo "欢迎 你 :$_COOKIE[usemame]"; /显示 登录 用 户 名 
echo "<p align=\"centen\">"; 

echo "<a href=19-18.php> 退 出 </a>"; /显示 退出 连接 

} 

echo "</td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td bgcolor=\"#eeeeff\">"; /以 下 用 JS 显示 一 个 日 历 
echo "<form name=f> 

<select name=year size=1 onchange=change()>"; 
for($i=2005;$i<2016;$i++) 


{ 
echo "<option value=".$i; 
if($i==date("Y")) echo " selected "; 
echo ">".$i; 

3 


echo "</select> 
<select name=month size=1 onchange=change()>"; 
for($i=1;$i<13;$i++) 


{ 
echo "<option value=".$i; 
if($i==date("n")) echo " selected "; 
echo ">". $i; 

} 


echo "</select></form> 

<div id=a1></div> 

<script language-javascript> 
tian=new Array(); 

tian[0]=31; 
tian[1]=28; 
tian[2]=31; 
tian[3]=30; 
tian[4]=31; 
tian[5]=30; 
tian[6]=31; 
tian[7]=31; 
tian[8]=30; 
tian[9]=31; 
tian[10]=30; 
tian[11]=31; 
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function change() 

í 
y=document.f.year.value; 
m=document.f.month.value; 
n=0,s=0; 
if(y%4==0) tian[1]=29; 
for(i=2005;i<y;i++) 
{ 


if(i%4==0) n=366; 
else n=365; 
s=s+n; 
} 
for(i=1;i<m;i++) 
í 
s=s+tian[i-1]; 
$ 
w=(s+6)%7; 
a1.innerHTML=\'\"; 
content=\"<table><tr><td> A </td><td> — </td><td> 二 </td><td> = </td><td> 四 </td><td> 五 </td><td> 六 
</td></tr>\"; 


t=1; 
for(i=0;i<42;i++) 
{ 
if(i%7==0) 
{ 
content=content+\"<tr>\"; 
} 
if((i>=w)&&(i<(tian[m-1])+w)) 
{ 
content=content+\"<td><a href=19-6.php?y=\"+y+\"&m=\"+m+\"&d=\"+t+\">\"+t+\"</a></td>\"; 
t+; 
} 
else 
{ 
content=content+\"<td>&nbsp;</td>\"; 
} 
if(i%7==6) 
{ 
content=content+\"</tr>\"; 
} 
} 


content=content+\"</table>\"; 
a1.innerHTML=content; 

j 

change(); 

function w open() 

{ 

open(\"19-18.php\"); 

} 
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</script>"; 
echo "</td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td bgcolor=\"#eeeeff\">"; 
echo "日 志 类 别 : <br>"; 
$sql="select sortname,sortnum from $table sort"; /显示 所 有 日 志 类 别 
$result=mysql_query($sql,$link); /发 送 SQL 请 求 
while($rows=mysql_fetch_array($result)) // 循 环 显示 类 别名 及 数量 
{ 
echo "<a href=19-6.php?sort=".$rows[0].">".$rows[0]."</a> (".$rows[1].") "; 
echo "<br>"; 
} 
echo "</td>"; 
echo "</tr>"; 
echo "</table>"; 
?> 


把 以 上 代码 保存 为 “19-4.php”， 以 备 后 用 。 
19.4 日 志 显 示 模块 
19.3 节 ， 介 绍 了 在 创建 程序 之 前 所 要 做 的 准备 工作 。 并 建立 了 配置 文件 ， 创 建 了 相应 的 数据 库 、 
表 ， 还 建立 了 显示 时 需要 调用 的 头 文件 与 侧 边 文件 ， 这 一 节 来 实现 日 志 显示 模块 。 该 模块 共有 以 下 几 
部 分 组 成 ， 如 主 显示 页 面 、 日 志 显示 页 面 、 日 志 详 细 信息 页 面 等 。 下 面 分 别 为 读者 做 介绍 。 


19.4.1 主 显示 页 面 的 创建 


这 一 小 节 来 创建 该 博客 程序 的 主页 文件 。 主 页 页 面 即 用 户 首次 可 以 看 到 的 页 面 ， 除 了 调用 头 文件 
与 侧 边 文件 显示 内 容 之 外 ， 它 还 有 以 下 几 个 内 容 ， 即 显示 最 新 日 志 、 显 示 最 新 留言 。 更 多 具体 内 容 请 
参看 以 下 代码 : 


T 

require "19-1.php"; // 调 用 配置 文件 
require "19-3.php"; // 调 用 头 文件 
echo "<table width=\"80%\">\n"; 

echo "<tr>"; 

echo "<td width=\"20%\">"; 

require "19-4.php"; 

echo "</td>"; 

echo "<td width=\"80%\">"; 

echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\" align=\"centef\" bgcolor=\"#000000\">\n"; 
echo "<tr>"; 

echo "<td bgcolor=\"#eeeeff\"> 最 新 日 志 </td>"; 

echo "</tr>"; 
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echo "<tr>"; 
echo "<td bgcolor=\"#eeeeff\">"; /显示 最 新 10 条 日 志 
$sgl-"select * from $table log where p_id=0 order by id desc limit 10"; 
$result=mysql_query($sql,$link); // 发 送 SQL 请 求 
$nums=mysql_num_rows($result); // 获 取 日 志 数量 
if($nums<1) echo "还 没有 任何 日 志 记 录 !"; // 如 果 没有 日 志 显 示 信息 
else // 如 果 有 日 志 
1 
while($rows=mysql_fetch_array($result)) // 通 过 循环 显示 内 容 
{ 
echo "<a href=19-5.php?id=".$rows[id].">".$rows[title]."</a>"; 
echo "<p>"; 
echo $rows[date]; 
echo "<p>"; 
echo $rows[content]; 
echo "<p>"; 


echo "<a href=19-7.php?id=".$rows[id]."> 阅 读 全 文 </a>|"; 

echo "<a href=19-6.php?sort=".$rows[som]."> 类 别 : ".$rows[sort]."</a>|"; 
echo "<a href=19-7.php?id=".$rows[id]."> 评 论 (".$rows[tbcount].") </a>|"; 
echo "<a href=19-7.php?id=".$rows[id]."> 浏 览 〈".$rows[views].") </a>"; 
echo "<hr width=\"100%\">"; 


} 
} 
echo "</td>"; 
echo "</tr>"; 
echo "</table>"; 
echo "<p>"; 
echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\" align=\Vcenten" bgcolor=\"#000000\">\n"; 
echo "<tr>"; 
echo "<td bgcolor=\"#eeeeff\"> HAAA </td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td bgcolor=\"#eeeeff\">"; // 显 示 最 新 10 条 留言 
$sql="select * from $table gbook order by id desc limit 10"; 
$result=mysql_query($sql,$link); /发 送 SQL 请 求 
$nums=mysql_num_rows($result); // 获 取 留 言 数量 
if($nums<1) echo "还 没有 任何 留言 !"; // 没 有 没有 留言 显示 信息 
else // 如 果 有 留言 


while($rows=mysql_fetch_array( $result)) // 通 过 循环 显示 内 容 
{ 

echo $rows[author]." 于 ".$rows[date]." 留 言说 : "; 

echo "<p>"; 

echo $rows[content]; 

echo "<hr width=\"100\">"; 


echo "</td>"; 
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echo "</tr>"; 
echo "</table>"; 
echo "</td>"; 
echo "</tr>"; 
echo "</table>"; 
echo "</center>"; 
echo "</body>"; 
echo "</html>"; 
?> 


把 以 上 代码 保存 为 “19-5.php”。 在 PHP 执行 环境 中 运行 该 文件 ， 其 执行 结果 如 图 19.3 所 示 。 为 
什么 会 这 样 ? 因为 这 时 并 没有 任何 日 志 ， 也 没有 任何 留言 ， 所 以 才 会 显示 如 图 19.3 所 示 的 执行 结果 。 


如 果 以 管理 员 身 份 登录 系统 并 添加 相应 的 类 别 及 日 志 ， 首 页 面 执行 结果 会 如 图 19.4 所 示 。 
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图 19.3 第 1 次 运行 主 显示 页 面 执行 结果 


图 19.4 第 2 次 执行 首页 显示 页 面 执行 结果 


此 时 的 首页 面 正确 显示 出 了 相应 的 日 志 及 日 志 类 别 ， 说 明 程序 正常 运行 。 


19.4.2 日 志 显示 页 面 的 创建 


这 一 小 节 来 创建 日 志 显示 页 ， 该 页 面 的 作用 是 显示 所 有 已 经 存在 的 日 志 ， 显 示 单 条 日 志 的 浏览 量 、 


评论 量 等 内 容 ， 并 且 还 具有 分 页 功能 。 同 时 还 应 该 
了 某 一 天 的 日 志 ， 则 只 显示 某 一 天 的 内 容 ; WRA 
内 容 。 

更 多 具体 内 容 参 看 以 下 代码 : 

<? 


根据 用 户 不 同 的 选择 显示 不 同 的 内 容 ， 如 用 户 选择 
目 户 选择 了 某 一 类 别 的 日 志 ， 则 只 显示 某 一 类 别 的 


require "19-3.php"; // 调 用 头 文件 


echo "<table width=\"80%\">\n"; 
echo "<tr>"; 
echo "<td width=\"20%\">"; 


require "19-4.php"; // 调 用 侧 边 文件 


echo "</td>"; 
echo "<td width=\"80%\">"; 
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echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\" align=\"centen\" bgcolor=\"#000000\">\n"; 
require "19-1.php"; // 调 用 配置 文件 
$link=mysql_connect($host,$user,$pass); 

mysql_select_ db($db name,$link); 


if£(($ GETIyland$ GETImJand$ GETId))) /如 果 没 有 日 期 输入 
{ 
if($ GETIsort)) // 如 果 有 类 别 输入 
{ 
$sort=$_GETIsort]; /获取 类 别 
echo "<tr>"; 
echo "<td bgcolor=\#eeeef"> 分 类 <font size=\"3\">[".$sort."]</font> 的 日 志 </td>"; 
echo "</tr>"; /显示 相应 类 别 


$sql="select * from $table sort where sortname='$sort"; 
$result=mysql_query($sql,$link); 
$rows=mysql_fetch_array($result); 
echo "<tr>"; 
echo "<td bgcolor=\#eeeef"> 类 别 介绍: ".$rows[description]."</td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td bgcolor=\#eeeef"'> 本 类 别 共 有 日 志 : ".$rows[sortnum]." 篇 </td>"; 
echo "</tr>"; 
if($rows[sortnum]>0) // 如 果 有 类 别 日 志 
{ 
echo "<tr>"; 
echo "<td bgcolor=\"#eeeeff\">"; 
$sql2="select * from $table log where sort='$sort and p_id=0"; 
$result2=mysql_query($sql2,$link); 
while($rows2=mysql_fetch_array($result2))/ 循 环 显示 


{ 
echo "<a href=19-7.php?id=".$rows2[id].">".$rows2[title]."</a>"; 
echo "<p>"; 
echo $rows2[date]; 
echo "<p>"; 
echo $rows2[content]; 
echo "<p>"; 
echo "<a href=19-7.php?id=".$rows2[id]."> 阅 读 全 文 </a>|"; 
echo "<a href=19-6.php?sort=".$rows2[sort]."> 类 别 ".$rows2[sort]."</a>|"; 
echo "<a href=19-7.php?i rows2[id]."> 评 论 (".$rows2[tbcount]."〉</a>|"; 
echo "<a href=19-7.php?id=".$rows2[id]."> 浏 览 (".$rows2[views].") </a>"; 
echo "<hr width=\"100\">"; 
} 
echo "</td>"; 
echo "</tr>"; 
} 
} 
else 1/ 如果 没有 任何 参数 
{ 


$sql="select id from $table log where p_id=0"; // 显 示 所 有 日 志 
Sresult=mysql_query($sql,$link); 


else 
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$msg_count=mysql_num_rows(S$result); /总 条 数 
$p_count=ceil($msg_count/10); /总 页 数 

echo "<tr>"; 

echo "<td bgcolor=\"#eeeeff\"> 全 部 日 志 </td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td bgcolor=\"#eeeeff\">"; 

if ($_GET["page"]==0 && !$_GET["page"]) 

$page=1; 

else 

$page=$_GET[page]; 

$s=($page-1)*10+1; 

$s=$s-1; 

$sql="select * from $table log where p_id=0 order by id desc limit $s, 10"; 
$result=mysql_query($sql,$link); 

$nums=mysql_num_rows($result); 

if($nums<1) echo "还 没有 任何 日 志 记 录 ! "， ”// 没 有 日 志 时 显示 信息 


else // 如 果 有 日 志 
{ 
while($rows=mysql_fetch_array($result)) // 循 环 显示 日 志 内 容 
{ 
echo "<a href=19-7.php?id=".$rows[id].">".$rows[title]."</a>"; 
echo "<p>"; 
echo $rows[date]; 
echo "<p>"; 
echo $rows[content]; 
echo "<p>"; 
echo "<a href=19-7.php?id=".$rows[id]."> 阅 读 全 文 </a>|"; 
echo "<a href=19-6.php?sort=".$rows[sort]. "> 类别 : ".$rows[sort]."</a>|"; 
echo "<a href=19-7.php?id=".$rows[id]."> 评 论 (".$rows[tbcount.") </a>|"; 
echo "<a href=19-7.php?id=".$rows[id]."> 浏 览 〈".$rows[views].") </a>"; 
echo "<hr width=\"100%\">"; 
} 
} 
echo "</td>"; 
echo "</tr>"; 
} 
// 如 果 有 日 期 参数 
$y=$_GET[y]; // 获 取 年 
$m=$_GET[m]; // 获 取 月 
$d-$ GETId); // 获 取 日 
$date=$y." 年 ".$m." 月 ".$d." 日 "; // 代 入 新 的 变量 中 
echo "<tr>"; 
echo "<td bgcolor=\"#eeeeff\">".$date." 的 日 志 </td>"; 
echo "</tr>"; 
echo "<tr>"; 


echo "<td bgcolor=\"#eeeeff\">"; /查找 当天 的 日 志 


=No» 
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$sql="select * from $table log where date like '$date'and p_id=0"; 
$result=mysql_query($sql,$link); 


$nums=mysql_num_rows($result); // 获 取 当 天 日 志 数量 
if($nums<1) echo "当天 没有 任何 日 志 记 录 !"; 1/ 如果 不 存在 
else /| 如果 存在 
í 
while($rows=mysql_fetch_array($result)) // 循 环 显示 
{ 
echo "<a href-19-7.php?id-".$rowslid).">".$rowsltitle)."</a>"; 
echo "<p>"; 
echo $rows[date]; 
echo "<p>"; 
echo $rows[content]; 
echo "<p>"; 
echo "<a href=19-7.php?id=".$rows[id]."> 阅 读 全 文 </a>|"; 
echo "<a href=19-6.php?sort=".$rows[sort]."> 类 别 ". $rows[sort]."</a>|"; 
echo "<a href=19-7.php?id=".$rows[id]."> 评 论 (".$rows[tbcount].") </a>|"; 
echo "<a href=19-7.php?id=".$rows[id]."> 浏 览 (".$rows[views].") </a>"; 
echo "<hr width=\"100\">"; 
J 
$ 
echo "</td>"; 
echo "</tr>"; 


if(($ GETIyland$ GETImland$ GETId)881($ GETIsort))) 


{ 


// 显 示 分 页 连接 

echo "<tr>"; 
echo "<td bgcolor=\"#eeeeff\">"; 
$prev_page=$page-1; 
$next_page=$page+1; 
if ($page<=1X{ 

echo "第 一 页 | "; 
3 
else{ 

echo "<a href='$PATH_INFO?page=1'> 第 一 页 </a> |" 
} 
if ($prev_page<1){ 
echo "上 一 页 |"; 
else{ 

echo "<a href='$PATH_INFO?page=$prev_page'> 上 一 页 </a> | "; 
} 
if ($next_page>$p_count}{ 

echo "下 一 页 |"; 
} 
else{ 

echo "<a href='$PATH_INFO?page=$next_page'> 下 一 页 </a> | "; 
} 
if ($page>=$p_countX{ 
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echo "最 后 一 页 </p>\n"; 
} 
else{ 
echo "<a href='$PATH_INFO?page=$p_count> 最 后 一 页 </a></p>\n"; 
} 
echo "</td>"; 
echo "</tr>"; 
} 
echo "</table>"; 
echo "</td>"; 
echo "</tr>"; 
echo "</table>"; 
?> 


将 以 上 代码 保存 为 “19-6.php”。 查 看 日 志 的 条 件 可 以 是 某 一 类 的 所 有 日 志 ， 也 可 以 是 某 一 天 所 写 
的 所 有 日 志 。 以 类 别 查 看 日 志 如 图 19.5 所 示 (前提 是 管理 员 后 台 登 录 并 添加 相应 类 别 及 日 志 ) 。 从 
图 19.5 可 以 发 现 ， 显 示 出 了 所 有 类 别 为 PHP 的 日 志 。 因 为 当前 只 有 一 篇 类 别 为 PHP 日 志 ， 所 以 只 显 
示 一 篇 。 

接 下 来 选择 左 侧 边 的 表单 为 2006 年 10 月 ， 再 单 击 18 日 图 标 ， 相 当 于 执行 
19-6.php?y=2006&m=10&d=18 命令 。 即 执行 19-6.php 同时 代入 年 、 月 、 日 参数 。 执 行 结果 如 图 19.6 
所 示 。 
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图 19.5 查看 某 一 类 别 的 日 志 执行 结果 图 19.6 查看 某 一 天 的 日 志 执行 结果 
从 以 上 两 次 执行 结果 可 以 看 出 ， 日 志 显 示 页 面 成 功 显示 出 了 按照 显示 条 件 所 列 出 的 所 有 日 志 。 


19.4.3 ”单条 日 志 详 细 信 息 页 面 的 创建 


19.4.2 小 节 创建 的 日 志 显示 页 面 ， 只 显示 相关 日 志 ， 并 不 显示 日 志 的 详细 情况 及 相关 的 评论 。 这 一 
节 来 创建 单条 日 志 详 细 信息 的 页 面 。 该 页 面 不 仅 显示 某 一 条 日 志 的 详细 信息 ， 而 且 还 显示 了 所 有 对 该 
日 志 的 评论 。 代 码 如 下 : 

<? 

reguire "19-3.php"; // 调 用 头 文件 

if(!$_POSTI[id]) // 如 果 没 有 评论 ID 输入 
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{ 

echo "<table width=\"80%\">\n"; 

echo "<tr>"; 

echo "<td width=\"20%\">"; 

require "19-4.php"; // 调 用 侧 边 文件 

echo "</td>"; 

echo "<td width=\"80%\">"; 

echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\" align=\"centen\" bgcolor=\"#000000\">\n"; 
require "19-1.php"; 


$link=mysql_connect($host,$user,$pass); // 连 接 主 机 
mysql_select_db($db_name,$link); // 选 择 库 

$sql="select * from $table log where id='$_GET[idl' order by id desc"; 
$result=mysql_query($sql,$link); /发 送 显示 某 一 条 日 志 的 SQL 请 求 
$rows=mysql_fetch_array($result,$link); // 置 入 数组 

echo "<tr bgcolor=\"#fffffA">"; 

echo "<td>"; 

echo "<h3>".$rowsltitle)."</h3>"; // 显 示 标题 

echo "</td>"; 

echo "</tr>"; 

echo "<tr bgcolor=\"#fffffA">"; 

echo "<td>"; 

echo $rowsltitle]; // 显 示 标 题 

echo "<p>"; 

echo $rows[date]; // 显 示 日 期 

echo "<p>"; 

echo $rows[content]; // 显 示 内 容 

echo "<p>"; 

echo "<a href=19-6.php?sort=".$rows[sort]."> 类 别 : ".$rows[sort]."</a>|"; 

echo "评论 (".$rows[tbcount].") |"; // 显 示 评 论 数 

echo "浏览 (".$rows[views].")"; // 显 示 浏 览 数 

echo "<hr width=\"100%\">"; 

echo "以 下 为 评论 内 容 : <br>"; /显示 对 该 条 日 志 的 评论 
$sql2="select * from $table log where p_id='$_GET[id]"; 
$result2=mysql_query($sql2,$link); // 发 送 SQL 请 求 
while($row2=mysql_fetch_array($result2,$link)) // 循 环 显 示 评 论 

echo "标题 : ".$row2[title]; /显示 评论 标题 

echo "<p>"; 

echo "AHA: ".$row2[date]; // 显 示 评 论 日 期 

echo "<p>"; 

echo "内 容 : ".$row2[content]; /显示 评论 内 容 

echo "<hr width=\"80%\">"; 

$ /下面 一 句 每 浏览 一 次 浏览 次 数 增加 1 
$sql="update $table log set views=views+1 where id='$_GET[id]"; 
mysql_query($sql, $link); // 发 送 自 增 1 的 SQL 请 求 
echo "</td>"; 

echo "</tr>"; 

echo "</table>"; 


echo "<p>"; 
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echo "<table cellpadding=\"1\" cellspacing=\"1\" align=\"centef\" bgcolor=\"#000000\">"; 


echo "<form action=19-7.php method=post>"; // 以 下 为 添加 评论 的 表单 
echo "<tr bgcolor=\"#eeffee\"><td>"; 
echo "发 表 评 论 : "; 


echo "<input type=hidden name=id value-".$rowslid).">"; 

echo "<input type=hidden name=sort value=". $rows[sort].">"; 

echo "</td></tr>"; 

echo "<tr bgcolor=\"#eeffee\"><td>"; 

echo "题目 : <input type=text name=title>"; 

echo "</td></tr>"; 

echo "<tr bgcolor=\"#eeffee\"><td>"; 

echo "评论 内 容 : <br><textarea name=content rows=5 cols=40></textarea>"; 
echo "</td></tr>"; 

echo "<tr bgcolor=\"#eeffee\"><td>"; 

echo "<input type=submit value=\" 发 表 \">"; 

echo "</td></tr>"; 

echo "</form>"; 

echo "</table>"; 

echo "</td>"; 

echo "</tr>"; 

echo "</table>"; 

} 

else // 处 理 用 户 提交 评论 
T 

$id=$_POSTIid]; /获取 各 项 参数 
$title=$_POST[title]; 

$sort=$_POST[sort]; 

$content=$_POST[content]; 

$date=$date=date("Y 4# n A d RA"); 

if(!$_COOKIE["usemame"]) // 如 果 没有 用 户 登录 
{ 

$username=" 匿 名 "; // 匿 名 用 户 


else 


í 

S$usemame=$_COOKIE["usemame"]; // 登 录用 户 

} 

require "19-1.php"; // 调 用 配置 文件 
$link=mysql_connect($host,$user,$pass); 

mysql_select_db($db_name, $link); 

$sql="insert into 
$table_ log(p id,author,title,content,sort,date)values('$id','Susername','$title','$content','$sort','$date')"; 
mysa! guery($sgi, $link); // 插 入 评论 记录 

$sql="update $table log set tbcount=tbcount+1 where id='$id"; 

mysa! guery($sgi, $link); // 评 论 数 自 增 1 

echo "<meta http-equiv=\"refresh\" content=\"2; url=19-7.php?id=".$id." ">"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "添加 成 功 评论 ， 正 在 返回 "; 
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echo "</body>"; 

echo "</html>"; 

} 

?> 

保存 以 上 代码 为 “19-7.php”。 

单 击 某 一 条 日 志 的 标题 ， 或 者 单 击 “阅读 全 文 ”链接 ， 均 可 以 进入 查看 该 条 日 志 详 情 的 页 面 ， 相 
当 于 执行 19-7.php。 如 查看 第 一 篇 PHP HE 〈 这 都 是 在 以 管理 员 身份 登录 系统 并 添加 相应 日 志 后 才能 
显示 的 ) ， 执 行 结果 如 图 19.7 所 示 。 
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19.7 查看 日 志 详情 执行 结果 


从 图 19.7 可 以 发 现 ， 成 功 显 示 出 了 当前 日 志 的 详细 内 容 及 所 有 评论 ， 并 且 可 以 通过 该 页 面 为 日 志 
添加 评论 。 说 明 程序 成 功 运行 。 


19.5 管理 模块 


这 一 节 来 创建 管理 模块 ， 管 理 模块 不 仅 包括 日 志 的 管理 ， 还 包括 用 户 信息 的 管理 、 留 言 管理 、 注 
册 用 户 管理 等 内 容 。 用 户 管理 使 每 个 用 户 可 以 修改 自己 的 注册 信息 。 而 日 志 管理 、 留 言 管理 、 所 用 注 
册 用 户 的 管理 则 属于 管理 员 特 有 的 权限 。 下 面 就 为 读者 作 一 一 说 明 。 


19.51 管理 员 /用 户 登 录 页 面 


这 一 小 节 来 创建 用 户 登录 页 ， 用 户 包括 普通 用 户 与 管理 员 。 管 理 员 登录 以 后 ， 可 以 对 博客 的 整体 
情况 进行 全 面 的 管理 ， 如 签 写 日 志 、 分 类 管理 、 日 志 管理 等 内 容 。 而 普通 用 户 登 录 之 后 则 可 以 行使 匿 
名 用 户 所 不 具有 的 权限 ， 例 如 对 日 志 发 表 评论 ， 浏 览 匿名 用 户 不 能 浏览 的 日 志 等 。 不 管 何 种 用 户 都 可 
以 更 改 该 用 户 注册 的 各 项 信息 。 

下 面 给 出 详细 内 容 : 
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<? 
if(!$_POST[usemame]) 
{ 
require "19-3.php"; // 调 用 头 文件 


echo "<script language=\"javascript\">\n"; 

echo "function juge(theForm)\n"; 

echo "Nn"; 

echo "\tif (theForm.username.value == \"\")\n"; 

echo "Win"; 

echo "Mai "RRA AAA l Van 

echo "t\ttheForm.admin.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "Man"; 

echo "tif (theForm.password.value == \"\")\n"; 

echo "Win"; 

echo "ttalert(\" 请 输入 密码 !\");\n"; 

echo "\t\ittheForm.pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "Ma"; 

echo "An"; 

echo "</script>\n"; 

echo "<center>\n"; 

echo "<table cellpadding=\"1\" cellspacing=\"1\" align=\"center\" bgcolor=\"#000000\" width=\"80%\">\n"; 
echo "<form method=\"post\" action=\"$PATH_INFO\ onsubmit=\"return juge(this)\">\n"; 
echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td colspan=\"2\" align=\"center\"> 管 理 员 / 用 户 登录 </td>\n"; 

echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td> 输 入 用 户 名 </td>\n"; 

echo "<td><input type=\"text\" name=\"usemame\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td> 输 入 密码 : </td>\n"; 

echo "<td><input type=\"password\" name=\"password\" size=\"21\"></td>\n"; 
echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td colspan=\"2\"><center><input type=\"submit\" value=\" 登 录 \"></center></td>\n"; 
echo "</tr>\n"; 

echo "</form>\n"; 


echo "</table>\n"; 
echo "</center>\n"; 
echo "</body>\n"; 
echo "<html>\n"; 
} 
else 
í 
$username=$_POST[username]; // 获 取 用 户 名 
$password=md5($_POST[Ipassword]); // 获 取 密 码 ， 并 用 MD5 加 密 


require "19-1.php"; // 调 用 配置 文件 
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$link=mysql_connect($host,$user$pass); // 连 接 主 机 
mysql_select_db($db_name,$link); // 选 择 数据 库 

$sql="select * from $table user where usemame-'$usemame' and password='$password"; 
$result=mysql_query($sql,$link) or die(mysql_error()); 


$row=mysql_num_rows($result); 1/ 获取 符合 的 用 户 数 量 
if($row<1) // 如 果 符合 的 数量 为 0 
{ 
require "19-3.php"; // 调 用 头 文件 
echo "<meta http-equiv=\"refresh\" content=\"2; url=19-8.php\">"; 
echo "用 户 名 或 者 密码 错误 两 秒 后 返回 !"; // 显 示 错 误 信息 
} 
else // 如 果 存 在 符合 条 件 的 用 户 
i 
setcookie("username","$username"); IREA COOKIE 
require "19-3.php"; // 调 用 头 文件 
echo "<table width=\"80%\">\n"; 
echo "<tr>"; 
echo "<td width=\"20%\">"; 
$rows=mysql_fetch_array($result); 1/ 用户 信息 置 入 数组 
echo "<table cellpadding=\"1\" cellspacing=\"1\" align=\"centen\" bgcolor=\"#000000\">\n"; 
echo "<tr>"; 


echo "<td bgcolor=\"#ffeeee\">"; 
echo "<a href=\"19-9.php\" target=\"fram\"> 用 户 信息 </a>"; 
echo "</td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td bgcolor=\"#eeffee\">"; 
echo "<a href=\"19-10.php\" target=\"fram\"> 更 改 密码 </a>"; 
echo "</td>"; 
echo "</tr>"; 
if($rows[admin]=="1") // 如 果 用 户 为 管理 员 ， 则 显示 更 多 操作 
echo "<tr>"; 
echo "<td bgcolor=\"#eeffee\"><a href=19-11.php target=\"fram\"> 分 类 管理 </a></td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td bgcolor=\"#eeffee\"><a href=19-16.php target=\"fram\"> 添 加 分 类 </a></td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td bgcolor=\"#eeffee\"><a href=19-12.php target=\"fram\"> 发 表 日 志 </a></td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td bgcolor=\"#eeffee\"><a href=19-13.php target=\"fram\"> 日 志 管 理 </a></td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td bgcolor=\"#eeffee\"><a href=19-14.php target=\"fram\"> 留 言 管理 </a></td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td bgcolor=\"#eeffee\"><a href=19-15.php target=\"fram\"> 用 户 管理 </a></td>"; 
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echo "</tr>"; 


echo "</table>"; 

echo "</td>"; 

echo "<td width=\"80%\">"; 

echo "<iframe name=\"fram\" src=\"19-9.php\" width=\"476\" height=\"350\" frameBorder=\"0\">"; 


echo "</td>"; 
echo "</tr>"; 
echo "</table>"; 
} 
} 
?> 


把 以 上 代码 保存 为 “19-8.php”。 现 在 就 可 以 用 管理 员 的 身份 登录 该 页 ， 以 便 执行 管理 分 类 、 添 加 
分 类 、 签 写 日 志 、 管 理 日 志 、 管 理 留言 、 管 理 用 户 等 操作 了 。 

首次 执行 19-8.php， 其 执行 结果 如 图 19.8 所 示 。 按 照 要 求 输入 用 户 名 及 密码 就 可 以 成 功 登录 系统 。 
成 功 登 录 后 的 界面 如 图 19.9 所 示 。 
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图 19.8 管理 /用 户 登 录 页 执行 结果 图 19.9 以 管理 员 身份 登录 后 执行 结果 


19.5.2 ”更改 用 户 注册 信息 


无 论 是 管理 员 或 者 是 普通 注册 用 户 都 有 权 更 改 已 经 注册 的 本 用 户 信 息 ， 这 一 节 就 来 创建 更 改 注册 
用 户 信息 的 页 面 。 
具体 内 容 参 看 以 下 代码 : 
<?php 
if(!$_COOKIE[usemame]) // 如 果 没有 登录 用 户 
"没有 用 户 登录 ! "; 
} 


else 


if(!$_POSTInickname]) // 如 果 没 有 发 送 表 单 变 量 ， 则 显示 HTML 
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echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 博 客 程序 一 一 显示 登录 用 户 信息 </title>\n"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "<script language=\"javascript\">\n"; 

echo “function juge(theForm)\n"; 

echo "An"; 

echo "if (theForm.nickname.value == \"\")\n"; 

echo "Win"; 

echo "\t\talert(\" 匿 称 必须 要 填 !\");\n"; 

echo "\t\ttheForm.nickname.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "tjn"; 

echo "An"; 

echo "</script>\n"; 

require "19-1.php"; 

$link=mysql_connect($host,$user,$pass); 

mysql_select_db($db_name, $link); 

$sql="select * from $table user where username='$_COOKIE[username]"; 

$result=mysql_query($sql,$link); 

$rows=mysql_fetch_array($result); /登录 用 户 信息 置 入 数组 

echo "<center>\n"; 

echo "<h1> 下 面 显示 登录 用 户 信息 </h1>"; 

echo "<h3> 如 果 需 要 更 改 用 户 信息 ， 直 接 更 改 即 可 </h3>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\" align=\"center\" 
bgcolor=\"#000000\">\n"; 

echo "<form action=19-9.php method=post onsubmit=\"return juge(this)\">"; 

echo "<tr>\n"; 

echo "<td bgcolor=\#ffffff"> 了 昵称 </td>\n"; 

echo "<td bgcolor=\"#fffff\"><input type=\"text\" name=\"nickname\" value=\""; 

echo $rows[nickname]; 

echo "\" ></td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td bgcolor=\V#ffffff"> 性 别 </td>\n"; 

echo "<td bgcolor=\"#fffffA">"; 

echo "<input type=radio name=sex value=boy "; 

if($rows[sex]=="boy") echo "checked"; 

echo " >boy"; 

echo "<input type=radio name=sex value=girl "; 

if($rows[sex]=="girl") echo "checked"; 

echo " >girl"; 

echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td bgcolor=\V#ffffff"> 重 新 输入 图 像 </td>\n"; 

echo "<td bgcolor=\"#fffffN\"><input type=\"text\" name=\"photo\" value=\""; 
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echo "\" ></td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td bgcolor=\"#fffff\">Email</td>\n"; 

echo "<td bgcolor=\"#fffff\"><input type=\"text\" name=\"email\" value=\""; 
echo $rows[emai 
echo "\" ></td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td bgcolor=\V#fffff"> 个 人 宣言 </td>\n'"; 

echo "<td bgcolor=\"#fffffA">"; 

echo "<textarea name=\"description\">". $rows[description]."</textarea>"; 

echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td bgcolor=\"#fffffì" colspan=\"2\"><center><input type=submit value=\" 确认 修改 


\"></center></td>\n"; 


else 


echo "</tr>\n"; 
echo "</form>"; 
echo "</table>\n"; 


// 如 果 发 送 表单 


S$nickname=$_POSTInickname]; // 获 取 表 单 变量 

$sex=$_POST[sex]; 

S$photo=$_POST[photo]; 

$email=$_POST[email]; 

$description=$_POST[description]; 

reguire("19-1.php"); 

$link=mysql_connect($host,$user,$pass); 

mysql_select_db($db_name, $link); 

$sql="update Stable_user set 


nickname='$nickname',sex='$sex',photo='$photo',email='$email',description='$description' where 
username='$_COOKIE[username]"; 


$result=mysql_query($sql,$link); /发 送 修改 表 内 容 的 SQL 请 求 
echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 博 客 程序 一 一 用 户 登录 <l/title>\n"; 

echo "<meta http-equiv=\"refresh\" content=\"2; url=19-9.php\">"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "用 户 信息 更 改 成 功 ! 两 秒 后 返回 "; 

echo "</body>"; 

echo "</html>"; 


把 以 上 代码 保存 为 “19-9.php”。 因 为 该 页 面 是 以 框架 形式 包含 在 19-8.php 中 的 ， 所 以 从 图 19.9 
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中 可 以 了 解 到 该 PHP 文件 的 执行 结果 ,， 即 图 19.9 的 右 下 方 所 显示 的 内 容 。 实 际 上 这 里 就 相当 于 执行 了 
19-9.php。 这 里 可 以 更 改 用 户 的 昵称 、 性 别 、 电 子 信箱 、 个 人 宣言 等 信息 。 需 要 注意 的 是 管理 员 的 个 人 
信息 将 显示 在 首页 页 面 上 .在 这 里 ,把 管理 员 的 昵称 由 dog 改 为 CAT, 个 人 宣言 改 为 "HELLO WORLD!” 
以 查看 19-9.php 的 执行 结果 。 进 行 相应 修改 并 单 击 “ 确 认 修改 ”按钮 之 后 ， 执 行 结 果 将 如 图 19.10 
所 示 。 
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图 19.10 更 改过 用 户 信息 之 后 的 执行 结果 
在 执行 过 这 一 步 的 操作 之 后 ， 单 击 最 上 面 的 首页 链接 ， 回 到 首页 将 会 看 到 显示 管理 员 信 息 的 区 域 
已 经 显示 了 新 的 信息 。 


19.5.3 更改 注册 用 户 密码 页 面 


因为 用 户 密 码 关系 着 用 户 账号 的 安全 ， 所 以 不 能 跟 用 户 其 他 信息 一 样 ， 而 是 要 单独 修改 。 这 样 可 
以 保护 密码 的 安全 ， 并 且 密码 都 是 把 用 户 的 输入 经 过 了 md5 的 加 密 。 就 算得 到 了 明码 ， 也 不 会 知道 密 
码 的 内 容 。 

具体 内 容 参考 以 下 代码 ; 


<?php 
if(!$_COOKIE[usemame]) // 如 果 没 有 登录 用 户 ， 则 显示 信息 


"没有 用 户 登 录 !"; 


} 
else // 如 果 用 户 已 经 登录 


if(!$_POST[old_pass]) // 如 果 没有 表单 发 送 ， 则 显示 HTML 
{ 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 博 客 程序 一 一 更 改 登录 用 户 密码 </title>\n"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "<script language=\"javascript\">\n"; 

echo "function juge(theForm)\n"; 

echo "An"; 

echo "\tif (theForm.old_pass.value == \"\")\n"; 
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echo "Win"; 

echo wwttalert(\" 请 输入 原始 密码 ! an 

echo "\t\ttheForm.old_pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "tjin"; 

echo "\tif (theForm.new pass.value == \"\")\n"; 

echo "Min"; 

echo "ttalert(\" 请 输入 新 密码 ! \");\n"; 

echo "t\ttheForm.new_pass.focus();\n"; 

echo "Wtretum (false);\n"; 

echo "\t}\n"; 

echo "tif (theForm.new_pass.value.length < 8 Jin"; 

echo "Win"; 

echo "\t\talert(\" 密 码 至 少 要 8 位! \");\n"; 

echo "\t\ttheForm.new_pass.focus();\n"; 

echo "\t\tretum (false);\n"; 

echo \t}\n"; 

echo "if (theForm.re_pass.value !=theForm.new_pass.value)\n"; 

echo "Win"; 

echo "\t\talert(\" 确 认 密 码 与 密码 不 一 致 ! \");\n"; 

echo "\t\ttheForm.re_pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "Win"; 

echo "An"; 

echo "</script>\n"; 

echo "<center>\n"; 

echo "<h3> 输 入 原始 密码 及 新 密码 </h3>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\" align=\"center\" 
bgcolor=\"#000000\">\n"; 

echo "<form action=19-10.php method=post onsubmit=\"return juge(this)\">"; 

echo "<tr>\n"; 

echo "<td bgcolor=V#ffffff"> 原 始 密码 ，</td>\n"; 

echo "<td bgcolor=\"#fffff\"><input type=\"password\" name=\"old_pass\" value=\""; 

echo "|" ></td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td bgcolor=\"#fffffh"> 新 密码 : </td>\n"; 

echo "<td bgcolor=\"#fffff\"><input type=\"password\" name=\"new_pass\" value=\""; 

echo \ ></td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td bgcolor=\"#fffffh"> 确 认 新 密码 : </td>\n"; 

echo "<td bgcolor=\"#fffff\"><input type=\"password\" name=\"re_pass\" value=\™; 

echo \ ></td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td bgcolor=\"#fffffì\" colspan=\"2\"><center><input type=submit value=\" 确 认 修 改 
\"></center></td>\n"; 

echo "</tr>\n"; 
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echo "</form>"; 
echo "</table>\n"; 


else // 如 果 发 送 表单 变量 


$old_pass=md5($_POST[old_pass]); // 获 取 表 单 变量 

$new_pass=$_POST[new_pass]; 

require "19-1.php"; 

S$link=mysql_connect($host,$user,$pass); 

mysg! select db($db name,$link); 

$sql="select “ from Stable user where username='$_COOKIE[username]' and 
password='$old_pass""; 


$reslut=mysql_query($sql,$link); /发 送 验证 用 户 身 份 的 SQL 请 求 
$row=mysql_num_rows(S$result); /符合 条 件 的 记录 数 
if($row< 1) // 如 果 不 存 在 符合 条 件 的 记录 ， 则 显示 信息 
{t 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 博 客 程序 一 一 用 户 登录 </title>\n"; 

echo "<meta http-equiv=\"refresh\" content=\"2; url=19-10.php\">"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "输入 的 密码 错误 ! 或 者 用 户 不 存在 ! 两 秒 后 返回 人"; 

echo "</body>"; 

echo "</html>"; 
} 
else // 如 果 旧 密码 正确 


$sql="update $table user set password-'$new pass' where username='$_COOKIE[username]' 
and password-'$0ld pass"; 

$result=mysql_query($sql,$link); /发 送 更 改 旧 密码 为 新 密码 的 SQL 请 求 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 博 客 程序 一 一 用 户 登录 </title>\n"; 

echo "<meta http-equiv=\"refresh\" content=\"2; url=19-10.php\">"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "更 改 成 功 ! 以 后 请 使 用 新 密码 登录 !"; 

echo "</body>"; 

echo "</html>"; 


} 


?> 


把 以 上 代码 保存 为 “19-10.php”， 以 便 在 用 户 需要 对 密码 进行 更 改 时 调用 该 文件 。 同 19-9.php 一 
样 ， 该 页 面 也 是 以 框架 形式 包含 在 19-8.php 中 的 。 由 于 修改 密码 操作 与 修改 用 户 信息 操作 基本 类 似 ， 
这 里 就 不 再 给 执行 结果 图 了 。 

用 户 信息 更 改 及 用 户 密码 更 改 是 所 有 用 户 都 拥有 的 权限 。 下 面 几 节 的 操作 就 是 只 有 管理 员 才 有 的 
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权限 ， 如 日 志 管理 、 分 类 管理 、 留 言 管理 和 用 户 管理 等 。 从 19.5.4 小 节 开 始 一 个 一 个 地 创建 这 些 页 面 。 
19.5.4 修改 已 经 存在 的 日 志 类 别 


日 志 的 类 别 是 日 志 的 一 个 重要 属性 ， 所 以 对 类 别 的 管理 也 很 重要 。 这 一 小 节 来 创建 类 别管 理 的 页 
面 。 和 签 写 新 日 志 功能 一 样 ， 这 当然 也 是 管理 员 才 有 的 超级 权限 ， 所 以 在 用 户 调用 该 页 时 要 对 用 户 的 
身份 进行 判断 。 

具体 内 容 参 看 以 下 代码 : 


<? 

if($_COOKIE[usemame]) // 如 果 用 户 已 经 登录 
require "19-1.php"; // 调 用 配置 文件 
$link=mysql_connect($host,$user$pass); 
mysql_select_db($db_name,$link); 
$sql="select * from $table user where username='$_COOKIE[username]"; 


$result=mysql_query($sql,Slink); /发 送 获取 用 户 信息 的 SQL 请 求 

$row=mysql_fetch_array($result); /用 户 信息 置 入 数组 

if ($row[admin]=="1") // 如 果 用 户 为 管理 员 ， 则 执行 以 下 操作 
if(!$_POST[action]) 1/ 如果 没 有 发 送 表 单 变量 ， 则 显示 HTML 
{ 


echo "<center>\n"; 
echo "<h3> 修 改 类 别 </h3>"; 
echo "<table cellpadding=\"1\" cellspacing=\"1\" align=\"centen\" bgcolor=\"#000000\ 
width=\"100%\">\n"; 
echo "<form method=\"post\" action=\"$PATH_INFO\">\n"; 
$sql="select * from $table sort"; /显示 所 有 已 经 存在 的 类 别 
$result=mysql_query($sql,$link); /发 送 SQL 请 求 
echo "<tr>\n"; 
echo "<td bgcolor=\"#ccffcc\"> 类 名 </td><td bgcolor=\"#ccffcc\"> 类 说 明 </td><td 
bgcolor=\"#ccffcc\"> 操 作 类 型 </td>\n"; 
echo "</tr>\n"; 
while($rows=mysql_fetch_array($result)) // 循 环 显示 所 有 类 
{ 
echo "<tr>"; 
echo "<input type=hidden name=id[$i] value=".$rows[id].">"; 
echo "<input type=hidden name=o_sort[$i] value=".$rows[sortname].">"; 
echo "<td bgcolor=\"#eeeeff\"><input type=text value=".$rows[sortname]." 
name=sortname[$i]></td><td bgcolor=\"#eeeeff\"><textarea name=description[$i] rows=3 
cols=20>".$rows[description]."</textarea></td>"; 
echo "<td bgcolor=\"#eeeeff\"><input type=radio name=action[$i] value=del checked> 删 除 
<br><input type=radio name=action[$i] value=edit> 修 改 <br></td>"; 
echo "</tr>"; 
$i++; 
} 
echo "<tr>"; 
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echo "<td colspan=\"3\" bgcolor=\"#eeffee\"><center>"; 
echo "<input type=submit value=\" 确 认 提交 \">"; 

echo "</center></td>"; 

echo "</form>\n"; 


echo "</table>\n"; 
echo "</center>\n"; 
echo "</body>\n"; 
echo "<html>\n"; 
} 
else // 如 果 发 送 表单 变量 ， 则 执行 操作 
{ 
require "19-1.php"; 1/ 调用 配置 文件 
S$link=mysql_connect($host,$user,$pass); // 连 接 MYSQL 主机 
mysql_select_db($db_name, $link); // 选 择 数 据 库 
for($i=0;$i<count($_POST[id]);$i++) // 根 据 操作 类 型 循环 执行 操作 
{ 
$temp1=$_POSTIidl[$i]; // 循 环 获取 表单 变量 
$temp2=$_POST[sortname][$i]; 
$temp3=$_POST[description] [$i]; 
$temp4=$_POST[o_sort][$i]; 
if($_POST[action][$i]J=="del") // 如 果 操作 类 型 为 删除 
{ 
$sql="delete from $table sort where id='$temp1"; 
$sql2="delete from $table log where sort='$temp2"; 
} 
else // 如 果 操作 类 型 为 修改 
$sql="update S$table sort set sortname='$temp2',description='$temp3' where 
id='$temp1"; 
$sql2="update $table log set sort='$temp2' where sort='$temp4"; 
} 
mysql_query($sql); /发送 对 类 的 相关 操作 的 SQL 请 求 
mysql_query($sql2); // 发 送 对 日 志 相关 操作 的 SQL 请 求 
3 
echo "<html>\n"; 
echo "<head>\n"; 
echo "<title> 博 客 程 序 </title>\n"; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=19-11.php\">"; 
echo "</head>\n"; 
echo "<body>\n"; 
echo "处 理 成 功 ， 正 在 返回 "; 
echo "</body>"; 
echo "</html>"; 
} 
J 
else // 如 果 用 户 不 是 管理 员 
echo "普通 用 户 没 有 该 权限 1"; /显示 信息 
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} 
else // 如 果 用 户 没 有 登录 
{ 
echo "你 还 没有 登录 ,点 <a href=19-8.php> 这 里 </a> 进 行 登录 ""; 
} 
?> 


保存 以 上 代码 为 “19-11.php”。 以 方便 管理 员 通 过 该 页 面 来 管理 已 经 存在 的 日 志 类 别 。 用 户 以 管 
理 员 身份 登录 系统 ， 并 执行 该 操作 时 ， 其 执行 结果 如 图 19.11 所 示 。 


alte 


Diad UA AA AI E 
图 19.11 分 类 管理 执行 结果 


从 图 19.11 可 以 发 现 , 现在 共有 两 个 类 别 , 这 里 对 默认 类 别 进行 修改 操作 , 先 选 择 操作 类 型 为 修改 ， 
类 名 文本 框 中 输入 PHP， 类 说 明文 本 框 中 输入 “PHP 编程 相关 内 容 ”。 对 第 2 个 类 不 进行 操作 ， 则 要 
选择 操作 类 型 为 修改 ， 其 中 各 项 内 容 保持 不 变 即 可 。 然 后 ， 单 击 “ 确 认 提交 ”按钮 ， 执 行 结果 如 19.12 
所 示 。 
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图 19.12 类 别 修改 过 之 后 的 执行 结果 
通过 图 19.12 可 以 发 现 ， 默 认 添 加 的 类 别 ， 已 经 被 改 成 了 PHP， 说 明 修改 操作 成 功 执行 。 


19.5.5 签 写 新 的 日 志 页 面 
由 于 刚 建成 的 系统 中 并 没有 任何 日 志 。 而 博客 程序 必须 要 使 管理 员 具 有 号 日 志 这 项 权限 ， 这 也 是 


最 基本 的 功能 。 这 一 小 节 来 创建 管理 员 签 写 新 日 志 的 页 面 。 
具体 内 容 参 看 如 下 代码 : 
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<? 
if($_COOKIE[usemame]) // 如 果 用 户 已 经 登录 
{ 
require "19-1.php"; // 调 用 配置 文件 
$link=mysql_connect($host,$user,$pass); // 连 接 主 机 
mysql_select_db($db_name,$link); /选择 数据 库 
$sql="select * from $table user where usemame='$ COOKIE[username]"; 
$result=mysql_query($sql,$link); // 发 送 获取 用 户 信息 的 SQL 请 求 
$row=mysql_fetch_array($result); /用 户 信息 置 入 数组 
if ($row[admin]=="1") // 如 果 用 户 为 管理 员 ， 则 执行 以 下 操作 
if(!$_POSTI[content]) // 如 果 没 有 发 送 表单 变量 ， 则 显示 HTML 
{ 


echo "<script language=\"javascript\">\n"; 

echo "function juge(theForm)\n"; 

echo "An"; 

echo "if (theForm.title.value == \"\")\n"; 

echo "tfn"; 

echo "titalert(\" 请 输入 日 志 标 题 !\");\n"; 

echo "\t\ttheForm .title.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo “tMn"; 

echo "tif (theForm.content.value == \"\")\n"; 

echo "Win"; 

echo "ttalert(\" 请 输入 日 志 内 容 ! \")\n"; 

echo "\t\ttheForm.content.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "itn"; 

echo "Jan"; 

echo "</script>\n"; 

echo "<center>\n"; 

echo "<table cellpadding=\"1\" cellspacing=\"1\" align=\Vcenten"” bgcolor=\"#000000\" 
width=\"100%\">\n"; 

echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)\">\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td colspan=\"2\" align=\"center> 签 写 新 的 日 志 </td>\n"; 

echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td> 日 志 标题 </td>\n"; 

echo "<td><input type=\"text\" name=\"title\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td> 所 属 类 别 </td>\n"; 

echo "<td><select name=\"sort\" size=\"1\">"; 

$sql="select sortname from $table sort"; 

Sresult=mysql_query($sql,S$link); 

while($rows=mysql_fetch_array($result)) 

£ 


echo "<option value=\""; 
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echo $rows[0]; 
echo "\">"; 
echo $rows[0]; 
} // 通 过 循环 显示 所 有 存在 类 别 
echo "</select></td>\n"; 
echo "</tr>\n"; 
echo "<tr bgcolor=\"#cccc99\">\n"; 
echo "<td> 日 志 内容 : </td>\n"; 
echo "<td><textarea rows=\"10\" cols=\"40\" name=\"content\"></textarea></td>\n"; 
echo "</tr>\n"; 
echo "<tr bgcolor=\"#cccc99\">\n"; 
echo "<td> 是 否 可 见 : </td>\n"; 
echo "<td><input type=radio name=\"hide\" value=n checked> 是 <input type=radio 


name=\"hide\" value=y> 否 </td>\n"; 


} 


else 


echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td colspan=\"2\"><center><input type=\"submit\" value=\" 确 认 提交 \></center></td>\n"'; 
echo "</tr>\n"; 

echo "</form>\n"; 

echo "</table>\n"; 

echo "</center>\n"; 

echo "</body>\n"; 

echo "<html>\n"; 


// 如 果 发 送 表单 变量 ， 则 执行 操作 


Stitle=$_POSTI[title]; 1/ 获取 表单 变量 

$content=$_POST[content]; 

S$hide=$_POST[hide]; 

$sort=$_POST[sort]; 

$date=date("Y Æ n A d R"); // 获 取 当 前 日 期 

require "19-1.php"; 

$link=mysqlL_connect($host,$user$pass); 

mysg| select db($db name,$link); 

$sql="insert into 


S$table_log(title, content, sort,author,hide,date)values('S$title','$content','$sort''$_COOKIE[usemame]','$hide','$dat 


e)"; 


mysql_query($sql,$link); /发 送 插入 新 日 志 记录 的 SQL 请 求 
$sql2="update $table sort set sortnum=sortnum+1 where sortname='$sort"; 
mysql_query($sql2, $link); // 发 送 更 改 类 别 数量 的 SQL 请 求 
echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 博 客 程 序 </title>\n"; 

echo "<meta http-equiv=\"refresh\" content=\"2; url=19-12.php\">"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "添加 成 功 ， 正 在 返回 "; 

echo "</body>"; 

echo "</html>"; 
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else // 如 果 用 户 不 是 管理 员 
echo "普通 用 户 没 有 该 权限 1"; 


} 
else // 如 果 没有 登录 用 户 
echo "你 还 没有 登录 ,点 <a href=19-8.php> 这 里 </a> 进 行 登录 ""; 

$ 

?> 

把 上 面 的 代码 保存 为 “19-12.php”。 这 样 ， 当 以 管理 员 身 份 登录 系统 以 后 ， 就 可 以 调用 该 页 面 来 
写 新 的 日 志 ， 或 者 叫 “ 写 博客 ”了 。 管 理 员 登录 之 后 ， 应 该 能 够 签 写 新 的 日 志 。 现 在 单 击 图 19.12 左 侧 
边 的 “发 表 日 志 ” 链 接 ， 相 当 于 执行 19-12.php。 执 行 结果 如 图 19.13 所 示 。 
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Dba COT Oea 
图 19.13 ” 签 写 新 的 日 志 执 行 结果 
为 了 方便 以 后 测试 ， 这 里 可 以 输入 几 条 以 作为 测试 之 用 。 
在 日 志 标题 文本 框 中 输入 “第 一 篇 PHP 日 志 ”， 类 别 选 择 “PHP” 选 项 ， 日 志 内 容 ， 随 便 填写 一 
些 内 容 以 作为 测试 ， 然 后 可 以 再 输入 一 条 类 别 为 JavaScript 的 记录 。 
发 表 日 志 之 后 ， 当 时 发 现 不 了 结果 ， 因 为 操作 成 功 之 后 都 又 跳 转 到 了 签 写 新 日 志 页 。 不 过 通过 下 
面 的 操作 就 能 看 到 所 写 的 日 志 了 。 


19.5.6 已 经 存在 的 日 志 管理 页 


写 过 的 日 志 ， 有 时 需要 进行 修改 ， 另 外 觉得 没有 用 的 日 志 也 要 进行 删除 。 所 有 这 些 操作 都 要 有 管 
理 权限 的 管理 员 才 能 进行 。 这 一 小 节 就 来 创建 日 志 的 管理 页 。 具 体内 容 请 参考 以 下 代码 : 


<? 
if($_COOKIE[usemame]) // 如 果 没 有 登录 用 户 
require "19-1.php"; // 调 用 配置 文件 


$link=mysql_connect($host,$user'$pass); // 连 接 主机 
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mysql_select_db($db_name,$link); // 选 择 数据 库 
$sql="select * from $table user where username='$_COOKIE[username]"; 
$result=mysql_query($sql,$link); /发 送 验证 用 户 身份 的 SQL 请 求 
$row=mysql_fetch_array($result); /用 户 信息 置 入 数组 
if ($row[admin]=="1") /| 如果 用 户 是 管理 员 ， 则 执行 以 下 操作 
{ 
if(!$_POST[action]) // 如 果 没 有 发 送 表单 变量 ， 则 显示 HTML 
{ 


echo "<center>\n"; 
echo "<h3> 日 志 管 理 </h3>"; 
echo "<table cellpadding=\"1\" cellspacing=\"1\" align=\"cente\" bgcolor=\"#000000\" 
width=\"100%\">\n"; 
echo "<form method=\"post\" action=\"$PATH_INFO\">\n"; 
$sql="select * from $table_log"; 
$result=mysql_query($sql,Slink); 
echo "<tr>\n"; 
echo "<td bgcolor=\"#ccffcc\">id</td><td bgcolor=\"#ccffcc\"> 标 题 </td><td bgcolor=\"#ccffcc\"> 
内 容 </td><td bgcolor=\"#ccffcc\"> 操 作 类 型 </td>\n"; 
echo "</tr>\n"; 
while($rows=mysql_fetch_array($result)) 
{ 
echo "<tr>"; 
echo "<input type=hidden name=id[$i] value=".$rows[id].">"; 
echo "<td bgcolor=\"#eeeeff\">".$rows[id]."</td>"; 
echo "<td bgcolor=\"#eeeeff\"><input type=text value=\"".$rowsltitle]."" name=title[$i] 
size=10></td>"; 
echo "<td bgcolor=\"#eeeeff\"><textarea name=content[$i] rows=3 
cols=20>".$rows[content]."</textarea></td>"; 
echo "<td bgcolor=\"#eeeeff\"><input type=radio name=action[$i] value=del checked=1> 删 
除 <br><input type=radio name=action[$i] value=edit> 修 改 <br></td>"; 


echo "</tr>"; 

$i++; 
} // 循 环 显示 日 志 内 容 及 操作 
echo "<tr>"; 


echo "<td colspan=\"4\" bgcolor=\"#eeffee\"><center>"; 
echo "<input type=submit value=\" 确 认 提交 \">"; 
echo "</center></td>"; 


echo "</form>\n"; 

echo "</table>\n"; 

echo "</center>\n"; 

echo "</body>\n"; 

echo "<html>\n"; 
} 
else // 如 果 表 单 变量 已 经 发 送 
{ 

require "19-1 .php"; // 调 用 配置 文件 


$link=mysql_connect($host,$user,$pass); // 连 接 主机 
mysql_select_db($db_name, $link); // 选 择 数据 库 
for($i=0; $i<count($_POST[action]);$i++) 

{ 
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$temp1=$_POSTIidl[$i]; // 循 环 获取 表单 变量 
Stemp2=$_POSTItitle]l[$i]; 

S$temp3=$_POST[contentl[$j; 
if($_POST[action][$1]=="del") // 如 果 操 作 类 型 为 删除 
$sql="delete from $table log where id-'$temp1'"; 
3 
else 1/ 如果 操作 类 型 为 修改 
{ 
$sql="update $table log set title='$temp2',content='$temp3' where id='$temp1"; 
l 
mysql_query($sql); /| 执行 删除 或 者 修改 操作 
} 
echo "<html>\n"; 
echo "<head>\n"; 
echo "<title> 博 客 程序 </title>\n"; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=19-13.php\">"; 
echo "</head>\n"; 
echo "<body>\n"; 
echo "处 理 成 功 ， 正 在 返回 "; 
echo "</body>"; 
echo "</html>"; 
} 
} 
else // 如 果 用 户 不 是 管理 员 ， 则 显示 信息 
echo "普通 用 户 没 有 该 权限 1"; 
} 
else // 如 果 用 户 没 有 登录 ， 则 显示 信息 
echo "您 还 没有 登录 ,点 <a href=19-8.php> 这 里 </a> 进 行 登录 "; 
} 
?> 


把 以 上 代码 保存 为 “19-13.php”。 单 击 图 19.13 左 侧 的 “ 


志 管 理 ” 链 接 ， 相 当 于 执行 19-13.php， 


其 执行 结果 如 图 19.14 所 示 。 


alo x) 
NOU MD EV RW IAD BB a 
L ji BI I Ea I EB ll EF ] B| 
日 志 管 理 

UA FE FEN 

aea a 

删除 

5 修改 
zi 
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图 19.14 日志 管理 页 面 执行 结果 
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这 里 显示 出 了 已 经 存在 的 日 志 ， 可 以 修改 日 志 的 标题 和 内 容 ， 也 可 以 选择 删除 某 一 条 日 志 ， 按 需 
要 进行 相关 操作 即 可 。 如 果 只 对 某 一 项 进行 操作 ， 其 他 项 保持 不 变 ， 则 操作 类 型 要 选择 修改 ， 其 他 的 
如 标题 与 内 容 保持 原样 即 可 。 


19.5.7 留言 的 管理 


相对 于 日 志 ， 留 言 是 一 个 更 为 开放 的 窗口 ， 里 面 可 能 充斥 着 大 量 的 有 用 的 或 者 没有 用 的 信息 ， 甚 
至 包括 乱七八糟 的 广告 或 者 带 毒 的 网 页 的 链接 。 对 这 些 内 容 要 进行 修改 或 者 删除 。 这 一 小 节 来 创建 留 
言 管理 的 页 面 。 和 其 他 的 管理 功能 一 样 ， 只 有 管理 员 才 有 权限 ， 才 能 在 用 户 调用 该 页 时 要 对 用 户 的 身 
份 进行 判断 。 
具体 内 容 参 看 以 下 代码 : 
<? 
if($_COOKIE[usemame]) // 如 果 用 户 已 经 登录 
t 
require "19-1.php"; // 调 用 配置 文件 
$link=mysql_connect($host,$user$pass); 
mysql_select_db($db_name,$link); 
$sql="select * from $table user where username='$_COOKIE[username]"; 
$result-mysg! guery($sgl,$link); 


$row=mysql_fetch_array($result); IAP ASEARA 
if ($row[admin]=="1") /用 户 为 管理 员 
if(I$ POSTlactionj) // 未 发 送 表单 变量 时 显示 HTML 
{ 
echo "<center>\n"; 
echo "<h3> 留 言 管 理 </h3>"; 


echo "<table cellpadding=\"1\" cellspacing=\"1\" align=\centen” bgcolor=\"#000000\" 
width=\"100%\">\n"; 
echo "<form method=\"post\" action=\"$PATH_INFO\">\n"; 
$sql="select * from $table_gbook"; 
Şresultzmysql_query ($sql, $link); 
echo "<tr>\n"; 
echo "<td bgcolor=\"#ccffcc\"> 作 者 </td><td bgcolor=\"#ccffcc\"> 标 题 </td><td 
bgcolor=\"#ccffcc\"> 内 容 </td><td bgcolor=\"#ccffcc\"> 操 作 类 型 </td>\n"; 
echo "</tr>\n"; 
while($rows=mysql_fetch_array( $result)) 
{ 
echo "<tr>"; 
echo "<input type=hidden name=id[$i] value=".$rows[id].">"; 
echo "<td bgcolor=\"#eeeeff\">".$rows[author]."</td><td bgcolor=\"#eeeeff\"><input 
type=text value-".$rowsltitle)." name=title[$i] size=6></td><td bgcolor=\"#eeeeff\"><textarea name=content[$i] 
rows=3 cols=20>".$rows[content]."</textarea></td>"; 
echo "<td bgcolor=\"#eeeeff\"><input type=radio name=action[$i] value=del checked> 删 除 
<br><input type=radio name=action[$i] value=edit> 修 改 <br></td>"; 
echo "</tr>"; 
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$i++; 
} /| 循环 显示 留言 内 容 
echo "<tr>"; 
echo "<td colspan=\"4\" bgcolor=\"#eeffee\"><center>"; 
echo "<input type=submit value=\" 确 认 提 交 \">"; 
echo "</center></td>"; 
echo "</form>\n"; 
echo "</table>\n"; 
echo "</center>\n"; 
echo "</body>\n"; 
echo "<html>\n"; 


else // 如 果 已 经 发 送 表单 变量 


require "19-1.php"; 
Slink=mysql_connect($host, $user,$pass); 
mysg! select db($db name,$link); 
for($i=0;$i<count($_POST][id]);$i++) 
{ 
$temp1=$_POSTT]id][$i]; // 人 循环 获取 表单 变量 
$temp2=$_POST][title][$i]; 
$temp3=$_POST[content][$i]; 
if($_POST[action][$i}=="del") // 如 果 操作 类 型 为 删除 
{ 
$sql="delete from $table gbook where id='$temp1"; 
} 
else // 如 果 操作 类 型 为 修改 


{ 
$sql="update $table gbook set title='$temp2',content='$temp3' where id='$temp1"; 


} 
mysql_query($sql); // 执 行 操作 SQL 语句 
} 
echo "<html>\n"; 
echo "<head>\n"; 
echo "<title> 博 客 程序 </title>\n"; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=19-14.php\">"; 
echo "</head>\n"; 
echo "<body>\n"; 
echo "处 理 成 功 ， 正 在 返回 "; 
echo "</body>"; 
echo "</html>"; 


else // 如 果 用 户 不 是 管理 员 
echo "普通 用 户 没 有 该 权限 1"; 


else // 如 果 用 户 没有 登录 


{ 
} 


?> 
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把 以 上 代码 保存 为 “19-14.php”， 由 于 该 功能 与 日 志 管理 类 似 ， 所 以 也 不 再 给 出 执行 效果 图 了 。 


19.5.8 注册 用 户 的 管理 


对 注册 用 户 进行 管理 也 是 管理 工作 中 一 个 很 重要 的 环节 。 通 过 该 页 面 ， 管 理 员 可 以 修改 注册 用 户 
的 信息 (但 是 一 般 情况 下 ， 不 主张 这 么 做 ) ， 甚 至 可 以 从 数据 库 中 删除 某 一 个 注册 用 户 。 
具体 内 容 参 看 如 下 代码 : 


<? 
if($_COOKIE[usemame]) // 如 果 用 户 已 经 登录 
{ 
require "19-1.php"; 1/ 调用 配置 文件 
S$link=mysql_connect($host, $user,$pass); // 连 接 主 机 
mysql_select_db($db_name,$link); // 选 择 数 据 库 
$sql="select * from $table user where username='$_COOKIE[username]"; 
$result=mysql_query($sql,$link); /验证 用 户 身份 
$row-mysgl fetch array($result); 
if ($row[admin]=="1") // 如 果 用 户 为 管理 员 
if(!$_POST[action]) // 如 果 没有 发 送 表 单 变量 ， 则 显示 HTML 
{ 
echo "<center>\n"; 
echo "<h3> 用 户 管理 </h3>"; 


echo "<table cellpadding=\"1\" cellspacing=\"1\" align=\"cente\" bgcolor=\"#000000\" 


width=\"100%\">\n"; 


echo "<form method=\"post\" action=\"$PATH_INFO\">\n"; 
$sql="select * from $table_user where admin!=1"; 
Sresult=mysql_query($sql,S$link); 

echo "<tr>\n"; 


echo 


"<td bgcolor=\"#ccffcc\">id</td><td ” bgcolor=\"#ccffcc"> 用 A 名 </td><td 


bgcolor=\"#ccffcc\"> 上 昵称 </td><td bgcolor=\"#ccffcc\"> 用 户 介 绍 </td><td bgcolor=\"#ccffcc\"> 操 作 类 型 </td>\n"; 
echo "</tr>\n"; 
while($rows=mysql_fetch_array( $result)) 


{ 


echo "<tr>"; 

echo "<input type=hidden name=id[$i] value=".$rows[id].">"; 

echo "<td bgcolor=\"#eeeeff\">". $rows[id]."</td>"; 

echo "<td bgcolor=\"#eeeeff\">".$rows[username]."</td>"; 

echo "<td bgcolor=\"#eeeeff\">"; 

echo "<input type=text name=nickname[$i] value=\"". $rows[nickname]."\" size=6>"; 

echo "</td>"; 

echo "<td bgcolor=\"#eeeeff\"><textarea name=description[$i] rows=3 


cols=20>".$rows[description]."</textarea></td>"; 


"390。 PHP 网 络 编程 从 入 门 到 精通 


echo "<td bgcolor=\"#eeeeff\"><input type=radio name=action[$i] value=del checked=1> 删 
除 <br><input type=radio name=action[$i] value=edit> 修 改 <br></td>"; 


echo "</tr>"; 

$i++; 
i // 循 环 显示 用 户 信息 
echo "<tr>"; 


echo "<td colspan=\"5\" bgcolor=\"#eeffee\"><center>"; 
echo "<input type=submit value=\" 确 认 提 交 \">"; 

echo "</center></td>"; 

echo "</form>\n"; 

echo "</table>\n"; 

echo "</center>\n"; 

echo "</body>\n"; 

echo "<html>\n"; 


else // 如 果 表 单 变 量 已 经 发 送 


require "19-1.php"; 
S$link=mysql_connect($host, $user,$pass); 
mysql_select_db($db_name,$link); 
for($i=0;$i<count($_POST[action]);$i++) 
{ 
$temp1=$_POST]id][$i]; // 循 环 获 取 变 量 
$temp2=$_POST[nickname][$i]; 
$temp3=$_POST[description] [$i]; 
if($_POST[action][$i]}=="del") 
{ 


} 


else 


{ 


$sql="delete from $table user where id='$temp1"; 


$sql="update $table user set nickname='$temp2',description='$temp3"; 


} 
mysql_query($sql); // 执 行 相关 SQL 操作 
} 
echo "<html>\n"; 
echo "<head>\n"; 
echo "<title> 博 客 程 序 </title>\n"; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=19-15.php\">"; 
echo "</head>\n"; 
echo "<body>\n"; 
echo "处 理 成 功 ， 正 在 返回 "; 
echo "</body>"; 
echo "</html>"; 


else // 如 果 用 户 不 是 管理 员 


echo "普通 用 户 没 有 该 权限 !"; 
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} 

} 

else // 如 果 用 户 没 有 登录 
echo "你 还 没有 登录 ,点 <a href=19-8.php> 这 里 </a> 进 行 登录 ""; 

} 

?> 


将 以 上 代码 保存 为 “19-15.php”， 以 备 后 用 。 单 击 图 19.14 左 侧 的 “用 户 管理 ”链接 ， 其 执行 结 
果 如 图 19.15 所 示 。 


DEEEF - Wcroseft Interact E 


alo x| 


YRO RBO REV MRO TAD MMD Ei 
xT E zz i F 
用 户 管理 
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图 19.15 用 户 管理 执行 结果 


从 图 19.15 可 以 看 出 ， 管 理 的 对 象 是 除了 管理 员 之 外 的 用 户 。 不 过 一 般 情 况 下 ， 就 算是 管理 员 也 不 
能 随意 更 改 用 户 的 昵称 和 用 户 介绍 。 更 不 能 把 用 户 从 列表 中 删除 。 但 是 ， 出 于 研究 目的 ， 这 些 知 识 还 
是 应 该 掌握 。 具 体操 作 方法 与 修改 类 别 相 类 似 ， 不 再 歼 述 。 


19.5.9 添加 新 类 别 页 面 


博客 程序 在 安装 过 程 中 为 用 户 建立 了 一 个 默认 的 日 志 类 别 。 这 显然 不 能 满足 用 户 的 需要 。 如 一 个 
程序 爱好 者 ， 可 能 会 写 PHP、ASP 或 者 JSP 等 多 种 类 型 的 日 志 ; 一 个 游戏 爱好 者 可 能 会 写 网 络 游戏 、 
单机 游戏 、 家 用 机 游戏 等 多 方面 的 日 志 。 所 以 要 给 予 用 户 创建 日 志 的 权限 。 实 现 该 功能 并 不 复杂 ， 在 
类 别 的 表 中 添加 一 项 记录 ， 然 后 在 用 户 签 写 新 的 日 志 时 ， 选 择 相应 的 类 别名 称 即 可 。 

具体 内 容 请 看 如 下 代码 : 


<? 
if($_COOKIE[usemame]) // 如 果 用 户 已 经 登录 
{ 
require "19-1.php"; 
S$link=mysql_connect($host, $user,$pass); 
mysg| select db($db name,$link); 
$sql="select * from $table user where usemame='$ COOKIE[username]"; 
$result=mysql_query($sql,$link); 
$row=mysql_fetch_array($result); 
if ($row[admin]=="1") // 验 证 用 户 如 果 为 管理 员 
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if(!$_POST[sortname]) /显示 HTML 
{ 
echo "<script language=\"javascript\">\n"; 
echo "function juge(theForm)\n"; 
echo "An"; 
echo "\tif (theForm.sortname.value == \"\")\n"; 
echo "tfn"; 
echo '\titalert( "RRA VA 
echo "\t\ttheForm.sortname.focus();\n"; 
echo "\t\treturn (false);\n"; 
echo "itin"; 
echo "\tif (theForm.description.value == \"\")\n"; 
echo "itin"; 
echo "tttalert(\" 请 输入 类 别 描 述 ! \");\n"; 
echo "\t\ttheForm.description.focus();\n"; 
echo "\t\treturn (false);\n"; 
echo "An"; 
echo "Jn"; 
echo "</script>\n"; 
echo "<center>\n"; 
echo "<table cellpadding=\"1\" cellspacing=\"1\" align=\"cente\" bgcolor=\"#000000\" 
width=\"100%\">\n"; 
echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)\">\n"; 
echo "<tr bgcolor=\"#cccc99\">\n"; 
echo "<td colspan=\"2\" align=\"centerW> 添 加 新 类 别 </td>\n"; 
echo "</tr>\n"; 
echo "<tr bgcolor=\"#cccc99\">\n"; 
echo "<td> 类 别名 称 </td>\n"; 
echo "<td><input type=\"text\" name=\"sortname\"></td>\n"; 
echo "</tr>\n"; 
echo "<tr bgcolor=\"#cccc99\">\n"; 
echo "<td> 类 别 描述 : </td>\n"; 
echo "<td><textarea rows=\"10\" cols=\"40\" name=\"description\"></textarea></td>\n"; 
echo "</tr>\n"; 
echo "<tr bgcolor=\"#cccc99\">\n"; 
echo "<td colspan=\"2\"><center><input type=\"submit\" value=\" 确 认 提 交 \></center></td>\n'"; 


echo "</tr>\n"; 

echo "</form>\n"; 

echo "</table>\n"; 

echo "</center>\n"; 

echo "</body>\n"; 

echo "<html>\n"; 
} 
else /| 执行 操作 
£ 


$sortname=$_POST[sortname]; 
$description=$_POST[description]; 
require "19-1.php"; 
$link=mysql_connect($host,$user,$pass); 
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mysql_select_db($db_name, $link); 
$sql="insert into $table_sort(sortname,description)values('$sortname','$description')"; 


mysql_query($sql,$link); /| 插入 新 类 别 
echo "<html>\n"; 
echo "<head>\n"; 
echo "<title> 博 客 程序 </title>\n"; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=19-16.php\">"; 
echo "</head>\n"; 
echo "<body>\n"; 
echo "添加 类 别 成 功 ， 正 在 返回 "; 
echo "</body>"; 
echo "</html>"; 
} 
} 
else 
{ 
echo "普通 用 户 没 有 该 权限 !"; 
} 
} 
else 
echo "你 还 没有 登录 ,点 <a href=19-8.php> 这 里 </a> 进 行 登录 人 "; 
A 


将 以 上 代码 保存 名 称 为 “19-16.php”。 这 样 ， 当 有 管理 员 登 录 系统 后 ， 就 可 以 调用 该 页 面 来 创建 
新 的 日 志 类 别 了 。 执 行 该 PHP 文件 ， 其 执行 结果 如 图 19.16 所 示 。 
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图 19.16 添加 分 类 执行 结果 

这 里 只 需要 输入 新 的 类 别名 称 及 类 别 描述 ， 然 后 单 击 “ 确 认 提交 ”按钮 即 可 。 执 行 完 操作 之 后 重 
新 跳 回 到 重新 输入 新 类 别 的 页 面 ， 不 再 重复 。 当 时 并 不 会 出 现 结 果 。 不 过 ， 在 执行 操作 “分 类 管理 ” 
时 或 者 返回 到 首页 就 能 看 到 结果 。 


19.5.10 留言 显示 与 发 表 页 面 


一 个 简单 的 留言 德 ， 可 以 有 效 的 在 管理 者 与 普通 浏览 者 之 间 连 起 一 条 纽带 。 所 以 通常 的 博客 程序 
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都 会 附带 一 个 留言 短 。 这 里 介绍 的 博客 的 程序 也 有 一 个 简单 的 留言 短 。 由 于 只 是 一 个 附带 的 产品 ， 所 
以 功能 都 尽 可 能 的 简单 ， 并 把 显示 与 用 户 添加 的 功能 集成 到 一 个 文件 之 中 。 
具体 内 容 参看 以 下 代码 : 


<? 

require "19-3.php"; // 调 用 头 文件 
if(!$ POSTItitle)) // 如 果 没 有 发 送 表 单 变量 ， 则 显示 HTML 
{ 

echo "<table width=\"80%\">\n"; 

echo "<tr>"; 

echo "<td width=\"20%\">"; 

require "19-4.php"; 

echo "</td>"; 

echo "<td width=\"80%\">"; 

echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\" align=\"centen\" bgcolor=\"#000000\">\n"; 
require "19-1.php"; 

$link=mysql_connect($host,$user,$pass); 
mysql_select_db($db_name, $link); 

$sgl-"select id from $table_gbook"; 
$result=mysql_query($sql,$link); 
$msg_count=mysql_num_rows($result);// 总 条 数 
$p_count=ceil($msg_count/10);// 总 页 数 

echo "<tr>"; 

echo "<td bgcolor=\#eeeef"> 全 部 留言 </td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td bgcolor=\"#eeeeff\">"; 

if ($_GET["page"]==0 && !$_GET["page"]) 

$page=1; 

else 

$page=$_GET[page]; 

$s=($page-1)*10+1; 

$s=$s-1; 

$sql="select * from $table gbook order by id desc limit $s, 10"; 
$result=mysql_query($sql,$link); 
$nums=mysql_num_rows($result); 

if($nums<1) echo "还 没有 任何 留言 记录 !"; 

else 


{ 


while($rows=mysql_fetch_array($result)) 
{ 
echo $rowsltitle)."</a>"; 
echo "<p>"; 
echo $rows[authonl." 于 ".$rows[date]." 留 言 : "; 
echo "<p>"; 
echo $rows[content]; 
echo "<hr width=100%>"; 
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echo "</td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td bgcolor=\"#eeeeff\">"; 
$prev_page=$page-1; 
$next_page=$page+1; 
if ($page<=1){ 
echo "第 一 页 |"; 
} 
else{ 
echo "<a href='$PATH_INFO?page=1'> 第 一 页 </a> | "; 
} 
if ($prev_page<1){ 
echo "上 一 页 |"; 
} 
else{ 
echo "<a href='$PATH_INFO?page=$prev_page'> 上 一 页 </a> |" 
} 
if ($next_page>$p_count){ 
echo "下 一 页 | "; 
} 
else{ 
echo "<a href='$PATH_INFO?page=$next_page'> 下 一 页 </a> | "; 
} 
if ($page>=$p_count){ 
echo "最 后 一 页 </p>\n"; 
} 


elsef 
echo "<a href='$PATH_INFO?page=$p_count> 最 后 一 页 </a></p>\n"; 
7 


echo "</td>"; 

echo "</tr>"; 

echo "</table>"; 

echo "<p>"; 

echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\" align=\Vcenten" bgcolor=\"#000000\">\n"; 
echo "<form action=19-17.php method=post>"; 

echo "<tr bgcolor=\"#eeffee\"><td>"; 

echo "发 表 新 留言 :"; 

echo "</td></tr>"; 

echo "<tr bgcolor=\"#eeffee\"><td>"; 

echo "留言 题目 : <input type=text name=title>"; 

echo "</td></tr>"; 

echo "<tr bgcolor=\"#eeffee\"><td>"; 

echo "留言 内 容 : <br> <textarea name=content rows=5 cols=40></textarea>"; 
echo "</td></tr>"; 

echo "<tr bgcolor=\"#eeffee\"><td>"; 

echo "<input type=submit value=\" 发 表 \">"; 

echo "</td></tr>"; 

echo "</form>"; 
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echo "</table>"; 
echo "</td>"; 
echo "</tr>"; 
echo "</table>"; 
echo "</td>"; 
echo "</tr>"; 
echo "</table>"; 
} 
else 
{ 
Stitle=$_POSTItitle]; 
$content=$_POST[content]; 
4$date=$date=date("Y 4# n A d A"); 
if(!$_COOKIE["username"]) 
í 
$username=" 匿 名 "; 
} 
else 


{ 
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// 如 果 已 经 发 送 表 单 变量 执行 操作 


$username=$_COOKIE["username"]; 


require "19-1.php"; 
$link=mysql_connect($host,$user,$pass); 
mysql_select_db($db_name, $link); 
$sql="insert into $table gbook(author title, 
mysql_query($sql, $link); 

echo "<meta http-equiv=\"refresh\" content 
echo "</head>\n"; 

echo "<body>\n"; 

echo "添加 留言 成 功 ， 正 在 返回 "; 

echo "</body>"; 

echo "</html>"; 

} 


?> 


把 以 上 代码 保存 为 “19-17.php”， 可 


上 方 的 “留言 ”链接 ， 相 当 于 执行 19-17] 
使 用 下 方 给 出 的 表单 添加 新 的 留言 。 
果 如 图 19.18 所 示 。 


„content,date)values('$username','$title''$content','$date')"; 
// 插 入 留言 内 容 到 表 中 
t=\"2; url=19-17.php\">"; 


[方便 普通 用 户 甚至 是 匿名 用 户 发 表 、 浏 览 留言 。 音 
php。 其 执行 结果 如 图 19.17 所 示 。 此 时 没有 任何 留言 


可 以 


输入 留言 标题 与 留言 内 容 之 后 ， 单 击 “ 发 表 ” 按 钮 即 可 。 执 行 结 


从 图 19.18 可 以 看 出 ， 正 确 显示 出 了 


户 所 提交 的 留言 内 容 。 说 明 程序 正常 运行 。 


19.5.11 新 用 户 注册 页 面 
一 个 博客 程序 的 用 户 当 然 不 能 只 有 管理 员 ， 也 应 该 有 更 多 的 普通 使 用 者 。 这 一 小 节 来 创建 新 用 户 
注册 页 面 。 在 进行 注册 时 要 先 判断 用 户 名 是 否 存在 ， 如 果 存 在 给 出 相应 的 提示 ; 反之 ， 则 将 用 户 输入 
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neti, 
ri 


TT Bee j a= 


图 19.17 查看 留言 页 面 执行 结果 


具体 内 容 参看 如 下 代码 : 


<? 


if(!$_POST[admin]) 


{ 


echo "<html>\n"; 

echo "<head>\n". 

echo "<title> 注 册 新 用 户 </title>\n"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "<script language=\"javascript\">\n"; 
echo "function juge(theForm)\n"; 

echo "An". 

echo "\tif (theForm.admin.value == \"\")\n"; 
echo "\tN\n"; 

echo "t\talert(\" 请 输入 用 户 名 称 ! \");\n"; 

echo "\t\ttheForm.admin.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "tn"; 

echo "\tif (theForm.pass.value == \"\")\n"; 
echo "tfn"; 

echo "titalert(\" 请 输入 用 户 密码 ! \")\n"; 

echo "\t\ttheForm.pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "tn"; 

echo "\tif (theForm.pass.value.length < 8 )\n"; 
echo "tfn"; 

echo "ttalert(\" 密 码 至 少 要 8 位! \");\n"; 
echo "\t\ttheForm.pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "tn"; 

echo "\tif (theForm.re_pass.value !=theForm.pass.value)\n"; 
echo "Win"; 

echo "ttalert(\" 确 认 密 码 与 密码 不 一 致 ! \");\n"; 


// 如 果 没 有 默认 参数 ， 


19.18 ”发表 留 言 执行 结果 


则 显示 HTML 
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echo "WitheForm.re pass.focus(); in"; 

echo "\t\treturn (false);\n"; 

echo "itn"; 

echo "\tif (theForm.nickname.value == \"\")\n"; 

echo "Win"; 

echo "tltalert(\" 请 输入 昵称 !\");\n"; 

echo "\t\ttheForm.nickname.focus()\n"; 

echo "\t\treturn (false);\n"; 

echo "Ma"; 

echo "An"; 

echo "</script>\n"; 

echo "<center>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\" align=\"center\" bgcolor=\"#000000\">\n"; 
echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)\">\n"; 
echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 注 册 新 用 户 </font></td>\n"; 
echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td> 用 户 名 : 〈 后 台 登 录 ) </td>\n"; 

echo "<td><input type=\"text\" name=\"admin\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td> 用 户 密码 : 〈 不 小 于 8 4ù) </td>\n"; 

echo "<td><input type=\"password\" name=\"pass\" size=\"21\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td> 确 认 密码 : </td>\n"; 

echo "<td><input type=\"password\" name=\"re_pass\" size=\"21\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td> H AÀ E-mail: CAN) </td>\n"; 

echo "<td><input type=\"text\" name=\"email\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<tdo HARER: (MARR) </td>\n"; 

echo "<td><input type=\"text\" name=\"nickname\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td> 用 户 介 绍 : </td>\n"; 

echo "<td><textarea rows=\"5\" cols=\"30\" name=\"description\"></textarea></td>\n"; 
echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td colspan=\"2\"><center><input type=\"submit\" value=\" 下 一 步 \"*></center></td>\n"; 
echo "</tr>\n"; 

echo "</form>\n"; 

echo "</table>\n"; 

echo "</center>\n"; 

echo "</body>\n"; 

echo "<html>\n"; 
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else // 如 果 有 POST 参数 ， 则 执行 操作 


$username=$_POST[admin]; // 获 得 参数 
$password=md5($_POST[pass]); 

$nickname=$_POST[nickname]; 

$email=$_POST[email]; 

$description=$_POST[description]; 

require "19-1.php"; 

$link=mysql_connect("$host","$user","$pass") or die(mysql_error()); 
mysql_select_db($db_name, $link); // 选 择 数据 库 

$sql="select username from $table user where username-'$username""; 
$result=mysql_query($sql,$link); 


$nums=mysql_num_rows($result); // 获 取 重 名 用 户 
if($nums!=0) echo "用 户 名 已 经 存在 ! 点 <a href='# onclick=history.go(-1)> 这 里 </a> 返 回 "; 
else // 如 果 不 存在 重 名 用 户 
{ 
$sql="insert into 


$table_user(username,password,nickname,email,description)values('$username' 
ail','$description')"; 

mysql_query($sql,$link) or die(mysql_error()); /发 送 添加 用 户 信息 的 SQL 请 求 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 注 册 新 用 户 </title>\n"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "</center>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\" align=\"center\" 
bgcolor=\"#000000\">\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td align=\"centen"><font size=\"5px\"> 注 册 用 户 </font></td>\n"; 

echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td align=\"center\"><font size=\"3px\"> 成 功 注册 ! </font></td>\n"; 

echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td align=\centen"> 点 <a href=\"19-8.php\"> 这 里 </a> 登 录 </td>\n"; 

echo "</tr>\n"; 

echo "</table>\n"; 

echo "</center>"; 

echo "</body>\n"; 

echo "</html>\n"; 


,'$password','$nickname','$em 


} 
?> 
把 以 上 所 示 代 码 保存 为 “19-18.php”。 在 PHP 执行 环境 中 运行 该 PHP 文件 , 其 执行 结果 如 图 19.19 
所 示 。 按 要 求 输入 想 要 注册 的 用 户 名 ， 再 输入 相应 的 密码 、 信 箱 、 简 介 等 内 容 即 可 。 单 击 “ 下 一 步 ” 
按钮 ， 将 出 现 如 图 19.20 所 示 的 执行 结果 。 
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图 19.19 新 用 户 注册 页 面 执行 结果 图 19.20 成 功 注册 新 用 户 执行 结果 


出 现 如 图 19.20 所 示 画 面 ， 说 明 新 用 户 注册 成 功 。 


19.5.12 用户 退 出 登录 页 面 


通常 不 需要 专门 创建 这 样 一 个 文件 ， 因 为 这 里 采用 的 Cookie 机 制 是 最 短 生命 期 ， 即 浏览 器 关闭 ， 
登录 用 户 注册 的 Cookie 即 失 效 。 但 是 为 了 方便 用 户 操作 还 是 有 必要 创建 这 样 一 个 页 面 。 实 现 功 能 相当 
简单 ， 清 除 用 户 注册 Cookie 返回 首页 。 

具体 内 容 请 参看 以 下 代码 : 

<? 

setcookie("usemame",""); // 把 相关 变量 置 为 空 值 

echo "<html>"; 

echo "<head>"; 

echo "<title> 退 出 登录 </title>"; 

echo "<meta http-equiv=\"refresh\" content=\"2; url=19-3.php\">"; 

echo "</head>"; 

echo "<body>"; 

echo "已 经 退出 ， 两 秒 后 返回 !"; 

echo "</body>"; 

?> 


保存 以 上 代码 为 “19-19.php”。 当 登录 用 户 单 击 图 19.7 左 侧 中 间 的 “退出 ”链接 相当 于 执行 
19-19.php。 程 序 将 会 清空 用 户 登 录 的 Cookie 完成 退出 任务 。 
至 此 ， 整 个 博客 系统 的 所 有 页 面 均 创建 完毕 。 


19.6 进一步 完善 


虽然 这 个 简单 的 博客 程序 已 经 能 够 正常 运行 了 。 但 还 存在 很 多 不 足 ， 与 网 上 同类 程序 相 比 功能 上 
还 差 得 比较 远 。 在 这 里 总 结 本 程序 的 不 足 ， 并 给 出 相关 的 解决 思路 ， 有 兴趣 的 读者 可 以 自行 解决 。 比 
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较 来 说 ， 有 以 下 几 个 方面 。 

没有 对 用 户 输入 内 容 进行 检测 。 用 户 的 输入 内 容 五 花 八 门 ， 更 有 不 怀 好 意 的 用 户 甚至 会 输入 恶意 
代码 。 解 决 这 个 问题 可 以 通过 相应 的 字符 串 操作 函数 ， 对 用 户 输入 信息 进行 处 理 。 

没有 文件 上 传 功能 。 有 时 用 户 需要 通过 博客 程序 把 本 地 的 文件 ， 如 图 片上 传 到 服务 器 。 解 决 这 
个 问题 可 以 为 管理 员 专门 再 建 一 个 文件 上 传 的 页 面 。 关 于 如 何 上 传 文件 请 参看 本 书 第 8 章 PHP 文件 
应 用 。 

没有 友情 链接 。 通 常 的 博客 程序 都 有 一 个 友情 链接 ， 以 使 管理 者 可 以 与 同类 的 ， 或 者 其 他 朋友 的 
网 站 建立 链接 ， 便 于 交流 。 这 个 实现 起 来 也 不 复杂 ， 只 需要 建 一 个 专门 的 表 用 于 放置 友情 链接 信息 ， 
然后 在 显示 时 显示 相应 的 网 站 链接 即 可 。 

经 过 功能 的 增加 ， 该 博客 程序 的 功能 相对 来 说 就 比较 完善 了 。 


19.7 关于 RSS 内 容 聚 合 


现在 所 见 到 博客 站 点 中 通常 都 有 一 个 RSS 的 链接 ， 这 也 是 博客 程序 一 个 明显 的 特征 。 网 络 上 曾经 
流行 这 样 一 段 话 “blogging without RSS is like swimming without water” 没 有 了 RSS 的 写 博客 就 相当 没 
有 水 的 游泳 。 看 起 来 RSS 对 博客 起 着 相当 重要 的 作用 。 虽 然 这 已 经 不 属于 PHP 编程 的 范畴 ， 但 作为 相 
关 知 识 ， 读 者 有 必要 作 一 下 了 解 。 

那么 究竟 什么 是 RSS， 它 与 博客 程序 又 有 什么 联系 呢 ? 

RSS (Really Simple Syndication) 是 一 种 描述 和 同步 网 站 内 容 的 格式 ， 是 目前 使 用 最 广泛 的 XML 
应 用 。RSS 搭建 了 信息 迅速 传播 的 一 个 技术 平台 , 使 得 每 个 人 都 成 为 潜在 的 信息 提供 者 。 发 布 一 个 RSS 
文件 后 ， 这 个 RSS Feed 中 包含 的 信息 就 能 直接 被 其 他 站 点 调用 ， 而 且 由 于 这 些 数据 都 是 标准 的 XML 
格式 ， 所 以 也 能 在 其 他 的 终端 和 服务 中 使 用 。 

如 果 从 RSS 阅读 者 的 角度 来 看 ， 完 全 不 必 考 虑 它 到 底 是 什么 意思 ， 只 要 简单 地 理解 为 一 种 方便 的 
信息 获取 工具 就 可 以 了 。RSS 获取 信息 的 模式 与 加 入 邮件 列表 〈 如 电子 杂志 和 新 闻 邮 件 ) 获取 信息 有 
一 定 的 相似 之 处 ， 也 就 是 可 以 不 必 登 录 各 个 提供 信息 的 网 站 而 通过 客户 端 浏览 方式 〈 称 为 “RSS 阅读 
器 ”) 或 者 在 线 RSS 阅读 方式 这 些 内 容 。 例 如 ， 通 过 一 个 RSS 阅读 器 ， 可 以 同时 浏览 新 浪 新 闻 ， 也 可 
以 浏览 搜狐 或 者 百度 的 新 闻 (如果 用 户 采 用 了 RSS 订阅 的 话 ) 。 

在 许多 新 闻 信 息 服务 类 网 站 ， 会 看 到 这 样 的 按钮 EE 到 EE 到 ， 有 的 网 站 使 用 一 个 图 标 ， 有 的 同 
时 使 用 两 个 ， 这 就 是 典型 的 提供 RSS 订阅 的 标志 ， 这 个 图 标 一 般 链 接 到 订阅 RSS 信息 源 的 URL。 当 
然 ， 即 使 不 用 这 样 的 图 标 也 是 可 以 的 ， 只 要 提供 订阅 RSS 信息 源 的 URL 即 可 。 

归纳 以 上 说 法 ， 概 括 来 说 ，RSS 其 实 就 是 一 种 站 点 与 站 点 之 间 的 信息 共享 方式 〈 也 称 内 容 聚 合 ) 。 
使 用 该 方式 之 后 ， 所 有 的 使 用 者 都 变 成 了 潜在 的 信息 提供 者 ， 这 样 会 更 有 利于 普通 网 络 使 用 者 发 现 网 
站 内 容 的 更 新 。 

关于 RSS 的 知识 就 简要 介绍 的 这 里 。 有 兴趣 的 读者 可 以 去 查阅 相关 的 专门 书籍 以 了 解 更 多 内 容 。 
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19.8 本 章 小 结 


这 一 章 为 读者 介绍 了 什么 是 BLOG, 普及 了 一 下 BLOG 的 知识 。 而 重点 是 介绍 如 何 用 PHP 程序 来 
完成 一 个 简单 的 BLOG 程序 。 把 一 个 简单 的 博客 程序 分 解 为 19 个 组 成 部 分 ， 每 部 分 ， 逐个 来 讲解 每 个 
模块 的 功能 及 代码 实现 。 并 对 执行 结果 进行 了 调试 分 析 。 通 过 本 章 学 习 ， 读 者 对 什么 是 博客 、 如 何 实 
现 一 个 博客 都 会 有 一 个 更 深层 次 的 认识 。 同 时 通过 本 章 的 学 习 ， 对 于 用 PHP 进行 MySQL 数据 库 的 操 
作 更 会 有 新 的 提高 。 
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BBS Æ # Bulletin Board System 的 缩写 ,翻译 成 中 文 为 “电子 布告 栏 系统 ”或 “ 电 
子 公告 牌 系 统 ”。BBS 是 一 种 电子 信息 服务 系统 ， 它 向 用 户 提供 了 一 块 公共 电子 白板 ， 
每 个 用 户 都 可 以 在 上 面 发 布 信息 或 提出 看 法 ， 早 期 的 BBS 由 教育 机 构 或 研究 机 构 管 理 ， 
现在 多 数 网 站 上 都 建立 了 自己 的 BBS 系统 ， 供 网 民 通过 网 络 来 结交 更 多 的 朋友 ， 表 达 
更 多 的 想法 。 目 前 国内 的 BBS 已 经 十 分 普遍 。 这 一 章 就 通过 PHP 来 设计 一 个 简单 的 BBS 
系统 。 本 章 内 容 包 括 BBS 相关 数据 表 的 设计 、 用 户 的 注册 与 登录 设计 、 用 户 发 贴 设 计 、 
主题 的 回复 与 显示 设计 、 管 理 员 对 贴 子 的 管理 、 用 户 的 管理 等 内 容 。 通 过 本 章 的 学 习 ， 
读者 可 以 更 进一步 提高 用 PHP 解决 实际 问题 的 能 力 。 


406" PHP 网 络 编程 从 入 门 到 精通 


BBS 大 致 可 以 分 为 5 类 : 

O 校园 BBS: CERNET 建立 以 来 ,校园 BBS 很 快 地 发 展 了 起 来 ， 目 前 很 多 大 学 都 有 了 BBS, 
几乎 遍及 全 国 上 下 。 像 清华 大 学 、 北 京 大 学 等 都 建立 了 自己 的 BBS 系统 ， 清 华 大 学 的 BBS 
水 木 清华 很 受 学 生 和 网 民 们 的 喜爱 。 大 多 数 BBS 是 由 各 校 的 网 络 中 心 建立 的 ， 也 有 私人 性 质 
的 BBS。 

口 商业 BBS 站 : 这 里 主要 是 进行 有 关 商 业 的 商业 宣传 ， 产 品 推荐 等 等 ， 目 前 手机 的 商业 站 、 计 
算 机 的 商业 站 、 房 地 产 的 商业 站 比比 皆 是 。 

O 专业 BBS 站 : 这 里 所 说 的 专业 BBS 是 指 部 委 和 公司 的 BBS， 它 主要 用 于 建立 地 域 性 的 文件 
传输 和 信息 发 布 系统 。 

O 情感 BBS: 主要 用 于 交流 情感 ， 是 许多 娱乐 网 站 的 首选 。 

口 个 人 BBS: 有 些 个 人 主页 的 制作 者 们 在 自己 的 个 人 主页 上 建设 了 BBS, 用 于 接受 别人 的 想法 ， 
更 有 利于 与 好 友 进 行 沟通 。 

这 一 章 就 通过 PHP 来 设计 一 个 简单 的 BBS 系统 。 本 章 内 容 包括 : BBS 相关 数据 表 的 设计 、 用 户 

的 注册 与 登录 设计 、 用 户 发 贴 设 计 、 主 题 的 回复 与 显示 设计 、 管 理 员 对 贴 子 的 管理 、 用 户 的 管理 等 内 
容 。 通 过 本 章 的 学 习 ， 使 读者 更 进一步 掌握 用 PHP 解决 实际 问题 的 能 力 。 


20.1 设计 数据 库 表 


数据 库 表 的 设计 是 Web 应 用 程序 开发 中 一 个 很 重要 的 环节 ， 表 结构 设计 的 好 坏 直 接 影 响 着 应 用 程 
序 的 执行 效率 。 一 个 设计 清晰 、 结构 合理 的 表 是 高 效应 用 程序 的 基础 。 这 一 节 就 来 分 析 一 下 , 简单 BBS 
系统 的 表 结 构 应 该 如 何 设计 。 其 中 包括 3 个 部 分 : 用 户 数 据 表 的 设计 、 论 坛 分 类 表 的 设计 、 贴 子 数据 
表 的 设计 。 


20.1.1 用 户 数据 表 的 设计 


这 一 小 节 先 来 学 习 简单 的 BBS 用 户 数据 表 的 设计 。 

一 般 的 用 户 表 应 该 包括 如 下 内 容 : 索引 ID、 用 户 名 《〈 用 户 登 录 时 使 用 的 名 称 ) 、 密 码 〈 用 户 登 录 
时 所 使 用 的 密码 ) 、 昵 称 《〈 与 用 户 名 不 同 ， 用 户 名 在 用 户 登 录 时 显示 ， 其 他 时 候 不 显示 ， 用 户 名 具有 
唯一 性 ， 而 昵称 则 在 用 户 发 贴 时 在 论坛 上 显示 ， 所 有 用 户 昵称 允许 出 现 重复 ) 、 性 别 〈 记 录用 户 的 性 
别 ) 、 电 子 信箱 〈 判 断 用 户 身份 的 一 个 重要 标志 ) 、 论 坛 图 像 (用户 发 贴 时 显示 的 图 像 》、 论 坛 签名 
〈 跟 在 发 的 贴 子 后 面 的 签名 ) 、 发 贴 数 〈 记 录用 户 总 共 的 发 贴 数量 )、 注 册 时 间 〈 记 录用 户 注册 的 时 间 ) 、 
版 主 〈 记 录用 户 的 权限 ， 分 为 普通 用 户 、 版 主 、 超 级 版 主 等 儿 种 ) 、 等 级 (由 发 贴 数 所 规定 的 一 个 等 级 ， 
发 贴 数 越 多 ， 等 级 越 高 ) 、 其 他 〈 备 用， 以 放置 用 户 其 他 信息 ) 。 每 个 字段 及 类 型 如 表 20.1 所 示 。 


表 20.1 用 户 数据 表 members 字段 类 型 及 含义 


其 他 属性 
记录 每 个 用 户 的 编号 ， 具有 唯一 性 auto_increment primary key 
记录 每 个 用 户 的 用 户 名 
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续 表 
字 段 名 作 用 其 他 属性 
password varchar 记录 用 户 的 密码 ， 用 MD5 加 密 保存 
nickname varchar 用 户 昵称 
sex enum('boy','girl') 记录 用 户 性 别 default 'boy' 
email varchar 记录 用 户 电子 信箱 
photo varchar 记录 用 户 图 像 
q_ name varchar 留言 时 显示 的 个 性 签名 
post num int 记录 用 户 发 贴 数 
reg date varchar 记录 用 户 注册 时 间 
admin i 记录 用 户 的 类 型 (管理 员 或 者 普通 用 户 ) 
levle 记录 用 户 等 级 
other 备用 项 


20.1.2 论坛 分 类 数据 表 的 设计 


一 个 论坛 ， 通 常 都 包括 很 多 子 栏目 。 如 一 个 以 编程 为 主题 的 论坛 下 面 可 能 分 为 技术 区 与 娱乐 区 
技术 区 可 能 又 会 分 为 网 络 编程 、 应 用 程序 编程 等 ， 下 面 可 能 会 有 更 为 复杂 的 划分 。 娱 乐 区 也 可 能 分 为 
灌水 区 、 贴 图 区 等 。 所 有 这 些 分 类 信息 都 要 保存 在 一 个 专门 的 表 之 中 。 

按照 以 上 考虑 ， 论 坛 分 类 数据 表 应 包括 以 下 内 容 : 索引 ID、 主 分 类 ID 论坛 的 大 类 ， 如 果 某 一 分 
类 项 为 主 分 类 ， 则 该 项 值 为 0， 反 之 该 项 值 为 其 主 分 类 ID 的 ID 号 ) 、 论 坛 分 类 名 称 〈 记 录 某 一 个 分 
类 的 名 称 )、 论 坛 分 类 介绍 (向 用 户 介 绍 该 分 类 的 主要 内 容 ) 、 最 后 贴 子 的 ID 号 (记录 最 后 一 条 贴 子 
内 容 以 显示 给 用 户 ) 、 该 分 类 的 总 帖子 数 〈 记 录 所 属 该 分 类 的 所 有 贴 子 的 数量 ) 、 该 分 类 的 总 主题 数 
〈 贴 子 数 包括 主题 数 ) 、 其 他 (备用 ， 以 存放 该 分 类 的 其 他 信息 )。 每 个 字段 及 其 类 型 如 表 20.2 所 示 。 


表 20.2 论坛 分 类 数据 表 topic 的 字段 类 型 及 含义 


字 BR 名 类 型 作 用 其 他 属性 

id int 记录 每 个 类 别 的 编号 ， 具 有 唯一 性 auto_increment primary key 
记录 该 类 别 所 属 主 类 别 ， 如 果 该 类 别 即 为 主 

可 类 别 ， 则 该 值 为 0 

topic name varchar 2 记录 该 类 别 的 名 称 

topic description varchar 

last post id int 记录 该 类 别 最 后 贴 号 

post_count int 记录 该 类 别 总 贴 数 

post m count int 记录 该 类 别 主 题 数 

other varchar 其 他 


至 此 ， 论 坛 分 类 表 的 设计 也 告 一 段落 。 
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20.1.3” 贴 子 数据 表 的 设计 


简单 的 论坛 系统 的 贴 子 表 采 用 这 样 的 结构 : 索引 ID、 所 属 分 类 ID (记录 该 贴 子 属于 哪 一 个 论坛 分 
类 ， 该 值 等 于 论坛 分 类 表 中 的 ID 号 ) 、 回 复 ID〈 该 贴 子 是 对 哪 一 条 贴 子 的 回复 ， 如 果 贴 子 本 身 就 是 
主题 ， 则 该 值 为 0) 、 贴 子 作者 的 ID 号 (这 一 条 记录 贴 子 作者 的 索引 号 ， 以 便 通 过 该 ID 号 显示 作者 
的 相关 信息 ) 、 贴 子 作者 的 名 称 、 贴 子 作者 的 IP 地 址 (记录 作者 的 IP 地 址 ) 、 贴 子 类 型 (可 分 为 求 
助 贴 、 原 创 贴 、 转 贴 等 多 个 类 型 ) 、 贴 子 的 标题 、 贴 子 的 内 容 〈 这 一 条 最 为 关键 ， 记 录 所 发 贴 子 的 内 
容 ) 、 贴 子 发 送 时 间 (记录 贴 子 发 送 于 何 时 ) 、 回 复 时 间 《〈 记 录 该 贴 子 最 后 回复 的 时 间 ) 、 其 他 ( 备 
用 ， 记 录 贴 子 的 其 他 信息 ) 。 

每 个 字段 及 其 类 型 如 表 20.3 所 示 。 


表 20.3 AFIRE posts 的 字段 类 型 及 含义 


字段 名 | 类 型 | 长 度 其 他 属性 
id int $ auto_increment primary key 
topicid | int 5 
. p 记录 该 贴 子 所 属 的 主题 。 如 果 该 贴 子 即 为 

re id int 5 H ` 

= 题 ， 则 该 值 为 0 
poster id | imt 5 
poster ip | varchar | 23 
poster varchar | 12 
poster type | varchar | 10 
title varchar | 40 
content text 
view count | int 5 
re_count int 5 记录 贴 子 回复 量 
post time | varchar | 40 

_post re time | _ varchar 40 记录 最 后 回复 时 间 

other Varchar 200 备用 


贴 子 数据 表 的 设计 也 宣告 完成 。 至 此 论坛 所 用 到 的 3 个 表 都 已 经 建立 完成 。20.2 节 就 开始 通过 代 
码 来 逐步 实现 论坛 的 所 有 功能 。 


202 准备 工作 


从 这 一 节 开始 将 通过 具体 代码 来 一 步 步 实现 论 坛 的 所 有 功能 。 不 过 在 具体 实施 之 前 ， 有 一 些 准备 
工作 必须 要 先 完成 。 这 一 节 就 来 解决 这 个 问题 。 
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20.2.1 配置 文件 的 创建 


通常 情况 下 ， 程 序 所 访问 的 主机 名 、 连 接 主机 的 用 户 名 、 用 户 密码 及 数据 库 名 都 是 固定 不 变 的 ， 
要 创建 的 各 种 表 名 ， 在 创建 后 也 是 不 变 的 ， 所 以 把 这 些 重要 的 变量 单独 拿 出 做 成 配置 文件 是 很 有 必要 
的 。 该 配置 文件 中 存放 着 程序 所 需要 的 数据 库 的 主机 名 、 连 接 主机 的 用 户 名 、 密 码 、 数 据 库 名 、 表 名 


等 各 项 信息 。 

下 面 就 来 建立 配置 文件 。 具 体内 容 参 看 以 下 代码 : 

<? 

$db host-"localhost"; // 主 机 名 
IAPR 

Y NEB 

$db_name="test"; /数据库 名 

$table members-"members"; IAPR 

$table topic-"topic"; /分 类 表 

S$table_posts="posts"; GFR 

$link=mysql_connect($db_host,$db_user,$db_pass); /| 连接 主机 

mysql_select_db($db_name, $link); /| 选择 数据 库 


?> 


把 以 上 代码 保存 为 “20-1.php”， 以 备 后 用 。 
20.2.2 ”安装 文件 的 创建 


配置 文件 创建 完成 ， 这 一 小 节 开始 来 创建 安装 文件 。 该 文件 的 作用 是 先 给 用 户 一 个 界面 ， 让 用 户 
完成 输入 相关 内 容 。 用 户 输入 完毕 后 ， 在 后 台 执 行 以 下 操作 : 分 别 创建 用 户 表 、 分 类 表 、 贴 子 表 ;， 为 
用 户 表 添 加 用 户 输入 的 管理 员 信息 、 为 分 类 表 添 加 默认 分 类 、 为 贴 子 表 添加 默认 的 贴 子 ; 给 出 用 户 相 
应 的 信息 。 

具体 内 容 请 参看 如 下 代码 : 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 安 装 程序 </title>\n"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "<style>\n"; 

echo™{ 

padding: 0; 

margin: 0; 

} 

body { 
font-family: verdana, sans-serif; 
font-size: 10pt; 
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background-color #FFFFEE; 
padding: 25px 0px 25px Opx; 
} 
a:link, a:active, a:visited { 
color: #336699; 
text-decoration: underline; 


} 

a:hover { 
color: #7F0000 !important; 
text-decoration: none; 

} 


select option { 
padding-right: 3px; 


} 
#content { 

padding: 0px 25px 10px 25px; 
} 


p, table, pre, h2, h3, ul, ol, dl { 
margin: Opx Opx 15px 0px; 


$ 

p-important { 
background-color: #EFDFBF; 
padding: 10px; 
font-size: 8pt; 

} 


p#submit, p#submit input { 
text-align: center; 
font-weight: bold; 


} 

p#submit input { 
padding: 5px; 

} 

h2{ 
color: #336699; 
font-weight: normal; 
font-size: 14pt; 
border-bottom: 1px solid silver; 

} 

h3{ 
color: #333; 
font-weight: bold; 
font-size: 10pt; 

} 

ul, ol { 
margin-left: 35px; 

} 

di dt { 


font-weight: bold; 
color: #333; 
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} 
di dd ( 
margin-left: 35px; 
margin-bottom: 5px; 
} 
table { 
background-color:#000000; 
border-collapse: collapse; 
margin-left: 0; 
margin-right: 0; 
} 
table th, table td { 
padding: 5px; 
} 
td{ 
background-color:#cccc99; 
} 
table th { 
text-align: left; 
color: #336699; 
} 
table td.title { 
width: 135px; 
y: 
echo "</style>\n"; 
if(!$_POST[admin]) // 如 果 没 有 默认 参数 ， 则 显示 HTML 


echo "<script language=\"javascript\">\n"; 
echo "function juge(theForm)in"; 

echo "An"; 

echo "tif (theForm.admin.value == \"\")\n"; 
echo "Win"; 

echo ”talert(\" 请 输入 管理 员 名 称 ! Van", 
echo "\t\ttheForm.admin.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "tn"; 

echo "\tif (theForm.pass.value == \\")\n"; 
echo "\tfn"; 

echo ttalert(v 请 输入 管理 员 密码 ! VAn"; 
echo "\t\ittheForm.pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "tn"; 

echo "\tif (theForm.pass.value.length < 8 )\n"; 
echo "Win"; 

echo "titalert(\" 密 码 至 少 要 8 位 ! \");\n"; 
echo "\t\ttheForm.pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "tn"; 

echo "\tif (theForm.re_pass.value !=theForm.pass.value)\n"; 
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echo "Win"; 

echo "ttalert(\" 确 认 密 码 与 密码 不 一 致 ! \");\n"; 
echo "WitheForm.re pass.focus(); in"; 

echo "Wtreturn (false);\n"; 

echo "An"; 

echo "tif (theForm.nickname.value == \"\")\n"; 
echo "Win"; 

echo "ttalert(\" 请 输入 昵称 ! \");\n"; 
echo "t\ttheForm.nickname.focus();\n"; 
echo "\t\treturn (false);\n"; 

echo "itn"; 

echo "tif (theForm.pre.value == \"\")\n"; 
echo "Win"; 

echo "Mai "RRA RRA \");\n"; 
echo "\t\ttheForm.pre.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "tAn"; 

echo "An"; 

echo "</script>\n"; 
echo "<center>\n' 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 

echo "<form method=\"post\" action=\"$PATH_INFO\ onsubmit=\"return juge(this)\">\n"; 
echo "<tr>\n"; 

echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 安 装 论 坛 </font></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 管 理 员 (后 台 登 录 ) </td>\n"; 

echo "<td><input type=\"text\" name=\"admin\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 管 理 员 密码 : 〈 不 小 于 8 位 ) </td>\n"; 

echo "<td><input type=\"password\" name=\"pass\" size=\"21\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 确 认 密码 : </td>\n"; 

echo "<td><input type=\"password\" name=\"re_pass\" size=\"21\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 管 理 员 E-mail: (可 选 ) </td>\n"; 

echo "<td><input type=\"text\" name=\"email\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<to RARR: (MART) </td>\n"; 

echo "<td><input type=\"text\" name=\"nickname\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 表 的 前 缀 : </td>\n"; 

echo "<td><input type=\"text\" name=\"pre\" value=\"bbs_\"></td>\n"; 

echo "</tr>\n"; 


else 
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echo "<tr>\n"; 

echo "<td colspan=\"2\"><center>\n"; 

echo "<input type=\"submit\" value=\" F —#\">\n"; 
echo "<input type=\"reset\" value=\" 重 新 填 \">\n"; 
echo "</center></td>\n"; 

echo "</tr>\n"; 

echo "</form>\n"; 

echo "</table>\n"; 

echo "</center>\n"; 

echo "</body>\n"; 

echo "<html>\n"; 


// 如 果 有 POST 参数 ， 则 执行 操作 


$name=$_POST[admin]; /获得 参数 
$password=md5($_POST[pass]); 
$nickname=$_POST[nickname]; 
$email=$_POST[email]; 
$pre=$_POST[pre]; 

require "20-1.php"; 

$table members=$pre.$table_members; 
$table topic-$pre.$table topic; 

Stable posts-$pre.$table posts; 
$ip=$_SERVER[REMOTE_ADDR]; 
$time=date("Y 4 m A d A"); 
$time2-date("G: i: s"); 

$sql="create table $table members( 

id int(5) not null auto_increment primary key, 
name varchar(12) not null, 

password varchar(40) not null, 

nickname varchar(12) not null, 

sex enum('boy','girl') not null default 'boy', 
email varchar(80) not null, 

photo varchar(80) not null, 

q_name varchar(200) not null, 

post_num int(5) not null, 

reg_date varchar(20) not null, 

admin int(1) not null default 'O', 

level int(5) not null, 

other varchar(200) not null 

六 


mysql_query($sql,$link) or die(mysql_error()); /发 送 创建 member 表 的 SQL 请 求 


$sql="create table $table topic( 

id int(5) not null auto_increment primary key, 
p_id int(5) not null, 

topic_name varchar(12) not null, 
topic_description varchar(80) not null, 
last_post_id int (5) not null, 

post_count int(5) not null, 


/获得 密码 ， 并 使 用 MD5 进行 加 密 操作 
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post m countint(5) not null, 

other varchar(200) not null 

六 

mysql_query($sql,$link) or die(mysql_error()); /发 送 创建 topic 表 的 SQL 请 求 
$sql="create table $table_posts( 

id int(5) not null auto_increment primary key, 

topic_id int(5) not null, 

re_id int(5) not null, 

poster_id int(5) not null, 

poster_ip varchar(23) not null, 

poster varchar(12) not null, 

title varchar(40) not null, 

content text not null, 

view_count int(5) not null, 

re_count int(5) not null, 

post_time varchar(40) not null, 

post_re_time varchar(40) not null, 

other varchar(200) not null 

J" 

mysql_query($sql,$link) or die(mysql_error()); /发 送 创 建 posts 表 的 SQL 请 求 
$sql="insert into $table_topic(p_id,topic_name,topic_description)values('0', 默 认 主 类 别 1',' 系 统 创建 的 默认 


EZAN" 
mysql_query($sql,$link) or die(mysql_error()); /发 送 添加 默认 主 分 类 的 SQL 请 求 
$sql="insert into 


$table _topic(p_id,topic_name,topic_description,last_post_id,post_count,post_m_count)values('1', 默 认 分 类 别 '， 
系统 创建 的 默认 分 类 别 ,1, 1 1) 

mysql_query($sql,$link) or die(mysql_error()); // 发 送 添加 默认 子 分 类 的 SQL 请 求 

$sql="insert into 
$table members(name,password,nickname,email,post num,reg date,admin)values('$name','$password','$nick 
name','$email','1','$time','3')"; 

mysql_query($sql,$link) or die(mysql_error()); /发 送 添加 管理 员 信 息 的 SQL 请 求 

$sql="insert into 
Stable posts(topic id,poster id,poster ip,postertitle,content,post time,post re time)values('2','1','$ip',$name',' 
第 一 条 测试 信息 ',' 测 试 发 贴 是 否 有 效 ','$time$time2','$timeS$time2")"; 

mysql_query($sql,$link) or die(mysql_error()); /发 送 添加 发 贴 的 SQL 请 求 

$sql="update $table topic set post count-'1',post m count-'1' where id='2"; 

mysql_query($sql,$link) or die(mysql_error()); /发 送 更 改 分 类 表 的 SQL 请 求 

$fp=fopen("20-1.php","w+"); // 将 更 新 过 的 数据 写 入 配置 文件 

fputs($fp,"<?\n"); 

fputs($fp,"\$db_host=\"localhost\";\n"); 

fputs($fp,"\$db_user=\"root\";\n"); 

fputs($fp,"\$db_pass=\"\";\n"); 

fputs($fp,"\$db_name=\"test\";\n"); 

fputs($fp,"\$table_members=\"$table_members\";\n"); 

fputs($fp,"\$table_topic=\"$table_topic\";\n"); 

fputs($fp,"\$table_posts=\"$table_posts\";\n"); 

fputs($fp,"\$link=mysql_connect(\$db_host,\$db_user,\$db_pass);\n"); 

fputs($fp,"mysql_select_db(\$db_name,\$link);\n"); 

fputs($fp,"?>"); 


} 


?> 
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fclose($fp); 

echo "<center>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\" align=\"centen\" bgcolor=\"#000000\">\n"; 
echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td align=\"center\"><font size=\"5px\"> 安 装 论坛 </font></td>\n"; 

echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td align=\"center\"><font size=\"3px\"> 成 功 安装 ! </font></td>\n"; 

echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td align=\"center\"><font size=\"3px\"> 删 除 该 文件 ， 以 减少 潜在 危险 ! </font></td>\n"; 
echo "</tr>\n"; 

echo "<tr bgcolor=\"#cccc99\">\n"; 

echo "<td align=\"center\"> <a href=\"20-3.php\"> 这 里 </a> 进 入 </td>\n"; 

echo "</tr>\n"; 

echo "</table>\n"; 

echo "</center>"; 

echo "</body>\n"; 

echo "</html>\n"; 


将 上 面 所 显示 的 代码 保存 为 “20-2.php”。 在 PHP 执行 环境 下 运行 该 PHP 文件 ， 以 完成 论坛 程序 
所 需 用 户 表 的 创建 。 首 次 运行 该 PHP， 其 执行 结果 会 如 图 20.1 所 示 。 

按照 要 求 填 入 全 部 信息 。 其 中 的 表 的 前 级 一 项 指 在 建立 表 时 为 了 避免 与 已 经 存在 的 表 出 现 重 名 现 
象 为 表 设 置 的 前 级 项 ， 全 部 填写 完毕 单 击 “ 下 一 步 ” 按 钮 ， 将 出 现 如 图 20.2 所 示 的 执行 结果 。 


| 
| ZMO MBO HEV KEA IRD HAO | æ 
司 
安装 论坛 
管理 员 ， (FERR) 
管理 只 密码 ， (不 小 et) | EEC -lo 
确认 密码 ， ——— (XO REU FEV RWO IAD HMW Le 
管理 员 E-mall，《 可 违 A 安装 论坛 
ERARE: ART) — TARRI 
表 的 前 级 : Pee- ooo HRUE, DREE 
EEA uu 点 这 里 进入 
到 z 
EE mlm ml Er 下 ua COO O zi 
图 20.1 首次 运行 安装 文件 的 执行 结果 图 20.2 安装 完成 执行 结果 


执行 过 这 一 步 操作 后 ， 系 统 所 需要 的 3 个 表 都 已 经 成 功 创建 完毕 ， 并 且 还 为 每 个 表 添 加 了 相应 项 
目 。 为 用 户 表 添 加 了 系统 管理 员 ， 为 分 类 表 添 加 了 默认 主 分 类 与 子 分 类 ， 为 发 贴 表 添加 了 第 1 条 贴 子 。 

系统 安装 程序 执行 过 后 ， 准 备 工作 就 算是 全 部 完成 了 。 接 下 来 就 是 每 个 功能 模块 的 具体 实现 了 。 
从 20.3 节 开 始 ， 就 通过 具体 的 代码 来 实现 论坛 的 具体 模块 。 
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203 用户 注册 与 登录 


论坛 与 用 户 是 密 不 可 分 的 。 用 户 的 多 少 是 评判 一 个 论坛 人 气 的 一 个 重要 标准 。 一 个 好 的 论坛 往往 


会 说 注册 用 户 达 到 多 少 万 ， 而 一 个 差点 的 论坛 的 注册 


用 户 一 个 友好 的 注册 与 登录 界面 。 这 


20.3.1 用 户 注册 页 


节 就 来 创建 


用 户 往往 很 少 。 既 然 需 要 注册 用 户 ， 就 要 提供 给 
户 的 注册 与 登录 页 。 


注册 新 用 户 页 提供 给 用 户 一 个 表单 ， 以 便 让 用 户 输入 相关 内 容 。 其 中 包括 必要 的 用 户 名 、 密 码 、 
昵称、 性 别 、 电 子 信箱 、 选 择 用 户 图 像 、 输 入 发 贴 签名 等 。 其 中 的 用 户 名 、 密 码 、 昵 称 几 项 内 容 为 必 


填 项 。 
具体 内 容 请 参考 以 下 代码 : 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 注 册 新 用 户 </title>\n"; 
echo "</head>\n"; 

echo "<body>\n"; 

echo "<style>\n"; 

echo™{ 

padding: 0; 

margin: 0; 


} 

body { 
font-family: verdana, sans-serif; 
font-size: 10pt; 
background-color: #FFFFEE; 
padding: 25px 0px 25px 0px; 


a:link, a:active, a:visited { 
color: #336699; 
text-decoration: underline; 


a:hover { 
color: #7F0000 limportant; 
text-decoration: none; 


select option { 
padding-right: 3px; 


#wrapper { 
width: 650px; 
border: 1px solid silver; 
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margin-left: auto; 
margin-right: auto; 
background-color: #EFEFEF; 
background-image: url(gfx/bg.png); 
background-repeat: repeat-x; 
} 
#wrapper h1 { 
height: 90px; 
line-height: 90px; 
background-image: url(gfx/logo.png); 
background-repeat: no-repeat; 
background-position: top right; 
padding: Opx 25px 0px 25px; 
font-weight: normal; 
font-size: 24pt; 
letter-spacing: -2px; 
word-spacing: 5px; 
color: #336699; 
} 
#content { 
padding: Opx 25px 10px 25px; 
} 
p, table, pre, h2, h3, ul, ol, dl { 
margin: Opx Opx 15px 0px; 


} 

p.important { 
background-color: #EFDFBF; 
padding: 10px; 
font-size: 8pt; 

} 


p#submit, p#submit input { 
text-align: center; 
font-weight: bold; 


} 

p#submit input { 
padding: 5px; 

} 

h2{ 
color: #336699; 
font-weight: normal; 
font-size: 14pt; 
border-bottom: 1px solid silver; 

} 

h3{ 
color: #333; 
font-weight: bold; 
font-size: 10pt; 

} 


ul, ol { 
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margin-left: 35px; 


di dt { 
font-weight: bold; 
color: #333; 
| 
di dd { 
margin-left: 35px; 
margin-bottom: 5px; 
3 
table { 
background-color:#000000; 
border-collapse: collapse; 
margin-left: 0; 
margin-right: 0; 
} 
table th, table td { 
padding: 5px; 
} 
td{ 
background-color:#cccc99; 
} 
table th { 
text-align: left; 
color: #336699; 
} 
table td.title { 
width: 135px; 
r 
echo "</style>\n"; 
if(!$_POST[user]) // 如 果 没 有 默认 参数 ， 则 显示 HTML 
i 


echo "<script language=\"javascript\">\n"; 
echo "function juge(theForm)\n"; 

echo "An"; 

echo "\tif (theForm.user.value == \"\")\n"; 
echo "An"; 

echo "ttalert(\" 请 输入 注册 用 户 名 ! \")i\n"; 
echo "\t\ttheForm.user.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "tin"; 

echo "\tif (theForm.pass.value == \\")\n"; 
echo "Win"; 

echo "talert(\" 请 输入 用 户 密码 ! VAT 
echo "\t\ttheForm.pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "tn"; 

echo "\tif (theForm.pass.value.length < 8 )\n"; 
echo "Win"; 
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echo "t\talert(\" 密 码 至 少 要 8 位 ! \")\n"; 

echo "\t\ttheForm.pass.focus()\n"; 

echo "\t\treturn (false);\n"; 

echo "itn"; 

echo "\tif (theForm.re_pass.value !=theForm.pass.value)\n"; 
echo "itin"; 

echo "titalert(\" 确 认 密 码 与 密码 不 一 致 ! \):n"; 
echo "\t\ittheForm.re_pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "tn"; 

echo "tif (theForm.nickname.value == \"\")\n"; 
echo "Win"; 

echo "t\talert(\" 请 输入 昵称 ! \");\n"; 

echo "\t\ttheForm.nickname.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "tn"; 

echo "An"; 

echo "function s_photo(the)\n"; 

echo "An"; 

echo "\tdocument.img.src='images/'+the.photo.value+'.bmp';\n"; 
echo "An"; 

echo "</script>\n"; 

echo "<center>\n"; 


echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<form method=\"post\" action=\"$PATH_INFO\ onsubmit=\"return juge(this)\">\n"; 


echo "<tr>\n"; 


echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 注 册 新 用 户 </font></td>\n"; 


echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 用 户 名 : 〈 后 台 登 录 ) </td>\n"; 

echo "<td><input type=\"text\" name=\"usen\"></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 用 户 密码 : 〈 不 小 于 8 位 〉</td>\n"; 


echo "<td><input type=\"password\" name=\"pass\" size=\"21\"></td>\n"; 


echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 确 认 密 码 : </td>\n"; 


echo "<td><input type=\"password\" name=\"re_pass\" size=\"21\"></td>\n"; 


echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 用 户 E-mail: (可 选 》</td>\n"; 

echo "<td><input type=\"text\" name=\"email\"></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 用 户 昵称 〈 前 台 显示 ) </td>\n"; 

echo "<td><input type=\"text\" name=\"nickname\"></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 
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20.3:2 
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echo "<td> 选 择 性 别 : </td>\n"; 
echo "<td>\n"; 
echo "<input type=\"radio\" name=\"sex\" value=\"boy\" checked> 男 \n"; 
echo "<input type=\"radio\" name=\"sex\" value=\"gif\"> 女 \n"; 
echo "</td>\n"; 
echo "</tr>\n" 
echo "<tr>\n"; 
echo "<td> 选 择 图 像 : </td>\n"; 
echo "<td>"; 
echo "<select name=\"photo\" size=\"1\" onchange=\"s_photo(this.form)\">\n"; 
for($i=1;$i<21;$i++) 
{ 
echo "<option value=".$i.">".$i."</option>\n";; 
$ 
echo "</select>"; 
echo "<img src=\"images/1.bmp\" name=\"img\">"; 
echo"</td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td colspan=\"2\"><center>\n"; 
echo "<input type=\"submit\" value=\" F —#\">\n"; 
echo "<input type=\"reset\" value=\" 重 新 填 \">\n"; 
echo "</center></td>\n"; 
echo "</tr>\n"; 
echo "</form>\n"; 
echo "</table>\n"; 
echo "</center>\n"; 
echo "</body>\n"; 
echo "<html>\n"; 


以 上 为 用 户 注册 的 前 台 显示 页 面 。20.3.2 小 节 介绍 用 户 注册 的 后 台 处 理 。 


注册 的 后 台 处 理 


注册 的 后 台 处 理 先 要 获取 用 户 输入 的 各 项 内 容 。 其 中 登录 用 户 名 是 最 为 重要 的 一 项 。 因 为 该 项 要 
求 具有 唯一 性 ， 即 同一 个 论坛 不 能 有 同名 用 户 的 出 现 ， 所 以 要 对 用 户 输入 的 用 户 名 进行 审核 。 这 就 会 
出 现 两 种 情况 : (1) 如 果 已 经 存在 同名 用 户 ， 则 给 出 错误 提示 ,并 要 求 用 户 重新 输入 新 的 用 户 名 ; (2) 
如 果 没 有 同名 用 户 ， 则 把 用 户 输入 信息 作为 一 条 新 的 记录 添加 到 用 户 表 中 。 

下 面 给 出 具体 的 处 理 过 程 。 请 参看 如 下 代码 : 


else 


{ 


/如果 有 默认 参数 ， 则 执行 操作 
$user=$_POST[user]; // 获 取 用 户 输 入 数据 
$pass=md5($_POST[pass]); /获取 密码 并 进行 MD5 处 理 


$email=$_POST[email]; 
$nickname=$_POST[nickname]; 
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$sex=$_POST[sex]; 


$time=date("Y 年 m 月 d A"); /获取 当前 时 间 
$photo=$_POST[photo].".bmp"; 
require "20-1 .php"; // 调 用 配置 文件 
$sql="select id from $table user where usemame='$user"; 
$result=mysql_query($sql,$link); /发 送 查 找 用 户 名 的 SQL 请 求 
$nums=mysql_num_rows($result); /获取 查找 结果 
if($nums!=0) /| 如 果 结果 不 等 于 0 
{ 
echo "注册 的 用 户 名 $user 已 经 存在 ! <p>"; // 给 出 相应 提示 
echo "请 点 <a href=# onclick=history.go(-1)> 这 里 </a> 返 回 ， 重 新 输入 新 的 用 户 名 ! "; 
exit(); // 退 出 所 有 PHP 操作 
} 
else // 如 果 结 果 为 0 
í 
$sql="insert into 


$table_ members(name,password,email,nickname,ser,photo,reg date)values('$user','$pass','$email',"$nicknam 
e','$sex','$photo','$time')"; 


mysql_query ($sql, $link); /发 送 插入 记录 的 SQL 请 求 
echo "新 用 户 $user 注册 成 功 ! <p>"; / 旺 示 成 功 提示 
echo "点 <a href=20-4.php> 这 里 </a> 进 行 登录 !"; 
} 
} 
?> 


把 以 上 代码 与 20.3.1 小 节 的 代码 结合 起 来 保存 为 “20-3.php”。 然后 在 PHP 执行 环境 下 运行 该 PHP 
文件 ， 首 次 运行 会 出 现 如 图 20.3 所 示 的 执行 结果 。 

按照 要 求 输入 相应 的 用 户 、 密 码 、 确 认 密 码 、 电 子 信箱 、 昵 称 及 选择 相应 的 图 像 后 单 击 下 一 步 按 
钮 。 如 果 用 户 名 已 经 存在 ， 则 会 出 现 如 图 20.4 所 示 的 提示 。 


Ia 对 
XO RAO FEV KAW IAV WHU E |e 
注册 新 用 户 
APZ MBER) 
用 户 密码 ，《 不 小 于 8 位 ) 
确认 密码 : 
用 户 E-mail，〔 可 选 ) 
用 户 昵称 ，《 前 台 显示 ) E alo 
选择 性 别 ， crk ZAO REO SEV HAW IAV HHW Li 
Seme. -Ei 注册 的 用 户 名 dog 已 经 存在 ! J 
下 一 步 | 重新 填 请 点 这 时 返回 ， 重 狐 答 入 狐 的 用 户 名 ! 
到 司 
Ua | EE ml Emen 4 
图 20.3 注册 新 用 户 执行 结果 图 20.4 注册 用 户 时 用 户 名 重复 执行 结果 


如 果 输 入 的 用 户 名 是 没有 注册 过 的 ， 则 会 出 现 如 图 20.5 所 示 的 执行 结果 。 
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AZ. 0 
文件 四 MEO SEV VAV IRV 帮助 90 & | 
a 
新 用 户 test 注 册 成 功 ! 
Aa ka 
E] 
Ea TT TT Bee 


图 20.5 注册 用 户 时 注册 成 功 执行 结果 
这 时 由 于 并 不 存在 重 名 用 户 ， 所 以 允许 用 户 注册 ， 并 将 用 户 的 输入 信息 写 入 用 户 列 表 中 ， 并 可 以 
使 用 该 用 户 登录 系统 了 。 
用 户 的 注册 及 注册 处 理 就 介绍 到 这 里 。20.3.3 小 节 来 讲解 用 户 的 登录 与 登录 处 理 。 


20.3.3 用 户 登 录 页 面 


用 户 信 息 添加 进 用 户 表 后 ， 就 要 让 用 户 能 够 正确 登录 到 系统 中 了 。 相 比 用 户 注册 ， 用 户 登 录 就 要 
简单 一 些 。 只 需要 给 出 用 户 名 及 密码 就 可 以 了 。 如 果 用 户 输入 信息 与 库 中 存在 的 一 致 ， 则 把 用 户 名 及 
相关 信息 存 为 Cookie 变量 。 谈 到 Cookie 在 用 户 登 录 时 也 可 以 为 用 户 提供 一 个 现在 比较 流行 的 Cookie 
保存 时 间 选 择 。 这 样 就 可 以 让 用 户 自由 选择 Cookie 的 保留 时 间 。 如 果 是 在 公用 计算 机 或 者 网 吧 使 用 论 
坛 系统 ， 就 设 为 最 短 时 效 即 关闭 浏览 器 清除 Cookie。 如 果 是 在 私有 计算 机 或 者 家 里 使 用 ， 则 可 以 设 为 
一 个 月 一 年 等 更 长 的 时 间 。 

下 面 给 出 用 户 登录 前 台 的 具体 代码 : 


<?php 
if(!$_POST[user]) // 如 果 没有 默认 参数 ， 则 显示 HTML 


{ 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 注 册 用 户 登录 </title>\n"; 
echo "</head>\n"; 

echo "<body>\n"; 

echo "<style>\n"; 


margin: 0; 


} 

body { 
font-family: verdana, sans-serif; 
font-size: 10pt; 
background-color: #FFFFEE; 
padding: 25px 0px 25px 0px; 


a:link, a:active, a:visited { 
color: #336699; 
text-decoration: underline; 
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a:hover { 
color: #7F0000 limportant; 
text-decoration: none; 

} 

select option { 
padding-right: 3px; 

} 

p, table, pre, h2, h3, ul, ol, dl { 
margin: 0px Opx 15px 0px; 


} 

h2{ 
color: #336699; 
font-weight: normal; 
font-size: 14pt; 
border-bottom: 1px solid silver; 

} 

h3{ 
color: #333; 
font-weight: bold; 
font-size: 10pt; 

} 

ul, ol { 
margin-left: 35px; 

} 

table { 
background-color:#000000; 
border-collapse: collapse; 
margin-left: 0; 
margin-right: 0; 

} 

table th, table td { 
padding: 5px; 

} 

td{ 
background-color:#cccc99; 

} 

table th { 
text-align: left; 
color: #336699; 

} 

table td.title { 
width: 135px; 

y: 


echo "</style>\n"; 

echo "<script language=\"javascript\">\n"; 
echo "function juge(theForm)\n"; 

echo "An"; 

echo "\tif (theForm.user.value == \"\")\n"; 
echo "Win"; 
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echo "ttalert(\" 请 输入 用 户 名 ! Van 
echo "“t\ttheForm.user.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "itn"; 

echo "\tif (theForm.pass.value == \"\")\n"; 
echo "itin"; 

echo "t\talert(\" 请 输入 用 户 密码 !\");\n"; 
echo "\t\ittheForm.pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "tn"; 

echo "An"; 

echo "</script>\n"; 
echo "<center>\n" 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 

echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)\">\n"; 
echo "<tr>\n"; 

echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 注 册 用 户 登 录 </font></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 用 户 名 :</td>\n"; 

echo "<td><input type=\"text\" name=\"usen\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 用 户 密码 :</td>\n"; 

echo "<td><input type=\"password\" name=\"pass\" size=\"21\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 选 择 COOKIE 有 效 期 : </td>\n"; 

echo "<td>"; 

echo "<select name=\"cook_t\" size=\"1\">\n"; 

echo "<option value=\"1\"> 最 短 时 效 </option>"; 

echo "<option value=\"2\">1 天 </option>"; 

echo "<option value=\"3\">1 月 </option>"; 

echo "<option value=\"4\">1 年 </option>"; 

echo "</select>"; 

echo"</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td colspan=\"2\"><center>\n"; 

echo "<input type=\"submit\" value=\" 下 一 步 \*>\n"; 

echo "<input type=\"reset\" value=\" 重 新 填 \">\n"; 

echo "</center></td>\n"; 

echo "</tr>\n"; 

echo "</form>\n"; 

echo "</table>\n"; 

echo "</center>\n"; 

echo "</body>\n"; 

echo "<html>\n"; 
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上 面 给 出 的 代码 是 用 来 显示 注册 用 户 登 录 的 前 台 。20.3.4 小 节 来 为 读者 介绍 用 户 登 录 的 后 台 处 理 。 


20.3.4 登录 出 错 及 处 理 


用 户 登 录 的 后 台 处 理 要 先 获取 用 户 输入 的 数据 ， 最 主要 是 用 户 名 与 密码 两 项 。 然 后 对 库 中 的 用 户 
数据 表 进 行 遍历 看 有 没有 相应 的 用 户 存在 。 如 果 存 在 相应 的 用 户 则 把 用 户 名 写 入 Cookie 变量 ， 并 根据 
用 户 的 选择 为 Cookie 设置 生命 期 限 ， 显 示 登 录 成 功 的 提示 ， 或 者 直接 跳 转 到 论坛 的 首页 。 反 之 ， 如 果 
不 存在 相应 的 用 户 或 者 密码 不 正确 则 给 出 错误 提示 ， 给 出 返回 上 页 的 链接 ， 让 用 户 再 次 输入 选择 。 

具体 处 理 过 程 请 参看 如 下 代码 : 


else 


{ 


$user=$_POST[user]; /| 获取 用 户 输入 参数 
$pass=md5($_POST[pass]); 

$cook t-$ POSTIcook 1]; 

require "20-1.php"; 

$sql="select id from $table members where name='$user and password='$pass"; 
$result=mysql_query($sql,$link) or die(mysql_error()); /查找 用 户 


$nums=mysql_num_rows($result); /把 查找 记录 数 赋值 给 变量 
if($nums==0) /如 果 记 录 数 为 0， 则 显示 内 容 
{ 


echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 注 册 用 户 登 录 </title>\n"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "<center>"; 

echo "<h2> 输 入 的 用 户 名 或 者 密码 错误 ! </h2>"; 

echo "<h3> 请 点 <a href=# onclick=history.go(-1)> 这 里 </a> 返 回 重新 输入 ! </h3>"; 
echo "</center>"; 


exit(); 

} 

else // 如 果 存 在 记录 的 处 理 

t if($cook_t==1) // 根 据 用 户 选择 注册 COOKIE 
setcookie("user","$user"); /最 短 


setcookie("user","$user",time()+60*60*24); WE 
P EN 
setcookie("user","$user',time()+60*60*24*30); // 一 月 


} 


else 
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setcookie("user","$user',time()+60*60*24*30*360); // 一 年 


} 
echo "<html>\n"; 
echo "<head>\n"; 


echo "<title> 注 册 用 户 登 录 </title>\n"; 


echo "</head>\n"; 
echo "<body>\n"; 
echo "<center>"; 


echo "<h2> 用 户 ".$user." 登 录 成 功 ! </h2>"; 
echo "<h3> 两 秒 后 进入 论坛 主题 页 面 ! </h3>"; 


echo "<meta http-equiv=\"refresh\" content=\"2; url=20-5.php\">"; 


echo "</center>"; 


} 
?> 


将 以 上 代码 与 20.3.3 小 节 所 列 的 用 户 登 录 页 面 代码 结合 起 来 ， 保 存 为 “20-4.php”。 在 PHP 执行 
环境 下 运行 该 文件 ， 执 行 结果 如 图 20.6 所 示 。 按 照 要 求 输入 相应 的 用 户 名 、 密 码 ， 单 击 “ 下 一 步 ” 按 
钮 开始 进行 登录 。 如 果 输 入 的 用 户 或 者 密码 错误 ， 则 会 出 现 如 图 20.7 所 示 的 出 错 提示 。 


LPO REO EV KUW IAW #MUW 
注册 用 户 登 录 
HPE: AA 
APEB: [ | 
Moo RA, |PER] 
Ts | asaj 


ain 

XAO RAV FEV MA IAD HHW Li 

输入 的 用 户 名 或 者 密码 错误 ! T 
请 点 这 里 返回 重新 输入 ! 


COT Er 


图 20.6 用 户 登录 页 面 执行 结果 


COO Er 


图 20.7 用 户 登 录 出 错 提示 


如 果 输 入 的 用 户 名 及 密码 是 库 中 已 经 存在 的 并 且 正 确 的 话 。 登 录 程 序 将 会 自动 跳 转 到 论坛 的 显示 
首页 20-5.php。 由 于 还 没有 编写 这 个 页 面 ， 所 以 应 该 会 出 现 无 法 找到 所 请 求 页 面 的 提示 。20.4 节 就 来 


着 手 编写 该 显示 首页 文件 。 


204 论坛 首页 、 主 论坛 、 分 论坛 显示 文件 的 创建 


论坛 的 表 创 建 完毕 ， 用 户 注册 登录 系统 也 都 完善 了 。 接 下 来 ， 就 开始 论坛 首页 、 主 论坛 、 分 论坛 


显示 页 面 文件 的 创建 。 


20.4.1 论坛 首页 显示 文件 的 创建 


论坛 首页 文件 是 整个 论坛 系统 中 最 为 重要 的 文件 。 通 常 的 论坛 首页 文件 有 以 下 作用 : 显示 用 户 是 
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容 ; 通常 还 会 在 下 方 给 出 当前 在 线 的 
没有 这 个 功能 ) 。 


否 登 录 ， 如 果 用 户 已 经 登录 则 显示 登录 用 户 名 ， 反 之 则 给 出 登录 链接 ,显示 所 有 主 分 类 及 其 所 属 的 子 
分 类 ， 某 一 分 类 的 总 贴 子 数 ， 其 中 的 主题 数 ， 最 后 发 贴 时 间 ， 最 后 的 作者 、 最 后 一 条 贴 子 的 标题 等 内 


户 〈 由 于 ， 本 章 所 介绍 的 BBS 系统 没有 设计 在 线 用 户 ， 所 以 就 


基于 这 些 需要 ， 一 步 步 来 创建 该 论坛 首页 文件 。 具 体内 容 请 参考 以 下 代码 : 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 论 坛 首 页 </title>\n"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "<style>\n"; 

echo "body { 
font-family: verdana, sans-serif; 
font-size: 10pt; 
background-color: #FFFFEE; 
padding: 25px Opx 25px 0px; 


} 

a:link, a:active, a:visited { 
color: #0033ff; 
text-decoration: underline; 

} 

a:hover { 
color: #7F0000 !important; 
text-decoration: none; 

} 


select option { 
padding-right: 3px; 

} 

p, table, pre, h2, h3, ul, ol, dl { 
margin: 0px Opx 15px 0px; 


} 

p.important { 
background-color: #EFDFBF; 
padding: 10px; 
font-size: 8pt; 

} 


p#submit, p#submit input { 
text-align: center; 
font-weight: bold; 

} 

p#submit input { 
padding: 5px; 

h2{ 
color: #336699; 
font-weight: normal; 
font-size: 14pt; 
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border-bottom: 1px solid silver; 


h3{ 
color: #333; 
font-weight: bold; 
font-size: 10pt; 

} 

ul, ol { 
margin-left: 35px; 

} 

di dt { 
font-weight: bold; 
color: #333; 

} 

di dd { 
margin-left: 35px; 
margin-bottom: 5px; 

} 

table { 
background-color:#000000; 
border-collapse: collapse; 
margin-left: 0; 
margin-right: 0; 

} 

table th, table td { 
padding: 5px; 

$ 

td{ 
background-color:#ddffff; 

} 

table th { 
text-align: left; 
color: #336699; 

} 

table td.title { 
width: 135px; 

y: 


echo "</style>\n"; 

echo "<center>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>\n"; 

echo "<td>"; 

echo "<center><h2> 论 坛 首 页 </h2></center>"; 

echo "</td>\n"; 

echo "</tr>\n"; 

echo "</table>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>\n"; 

echo "<td>"; 

if(!$_COOKIE[user]) // 如 果 没 有 用 户 登录 ， 则 显示 登录 连接 
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{ 
echo "<a href=\"20-4.php\"> 用 户 登 录 </a>"; 
} 
else // 如 果 用 户 已 经 登录 ， 则 显示 登录 用 户 名 
{ 
require "20-1.php"; 
$sql="select id from $table members where name='$_COOKIE[user]"; 
$result=mysql_query($sql,$link); 
$rows=mysql_fetch_array($result); 
echo "登录 用 户 : <a href=20-14.php?id=".$rows[0].">".$_COOKIE[user]."</a>"; 
} 
echo "</td>\n"; 
echo "</tr>\n"; 
echo "</table>\n"; 


echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>\n"; 
echo "<td> 论 坛 名 称 </td><td> 论 坛 介绍 </td><td> 贴 子 数量 </td><td> 主 题 数 量 </td><td> 最 后 贴 子 标题 </td><td> 最 
后 贴 子 回 复 时 间 </td>\n"; 
require "20-1.php"; 
$sql="select * from $table topic where p_id=0"; // 遍 历 贴 子 种 类 表 显 示 主 论坛 
$result=mysql_query($sql,$link) or die(mysql_error()); 
while($rows=mysql_fetch_array($result) 
f 
echo "<tr>\n"; /显示 主 论坛 的 标题 及 其 介绍 
echo "<td colspan=\"6\"><a href=\"20-6.php?id=".$rows[id]."\">".$rows[topic_name]."</a> 
" $rows[topic_description]."</td>\n"; 
echo "</tr>\n"; 
$temp2-$rowslid); 
$sgl2-"select * from $table topic where p_id='$temp2"; /遍历 种 类 表 显 示 主 论坛 下 的 分 论坛 
$result2=mysql_query($sql2,$link) or die(mysql_error()); 
while($rows2=mysql_fetch_array($result2)) /显示 分 论坛 的 各 项 信息 
echo "<tr>\n"; 
echo "<td><a href=\"20-7.php?id=".$rows2[id]."\">".$rows2[topic_name]."</a></td>\n"; 
echo "<td>".$rows2[topic_description]."</td>\n"; 
echo "<td>".$rows2[post_count]."</td>\n"; 
echo "<td>".$rows2[post_m_count]."</td>\n"; 
$sql3="select id,title,post re time from $table posts where id='$rows2[last_post_id]"; 
$result3=mysql_query($sql3,$link) or die(mysql_error()); 
$rows3=mysql_fetch_array($result3); /显示 最 后 一 条 贴 子 的 相关 信息 
echo "<td><a href=\"20-8.php?id=".$rows3[id]."\">".$rows3[title]."</a></td>\n"; 
echo "<td>".$rows3[post_re_time]."</td>\n"; 
echo "</tr>\n"; 
} 
echo "<tr><td colspan=\"6\">&nbsp;</td></tr>\n"; 


echo "</table>\n"; 
echo "</center>\n"; 
echo "</body>"; 
echo "</html>"; 

?> 
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将 以 上 代码 保存 为 “20-5.php”。 由 于 系统 在 创建 时 已 经 创建 了 默认 的 主 论坛 和 分 论坛 ( 详 见 20.2.2 
小 节 )， 所 以 目前 显示 时 显示 的 只 有 1 个 默认 的 主 论坛 与 其 下 的 一 个 分 论坛 。 执 行 结果 如 图 20.8 所 示 。 


BASE 
XEO MU SEV PRW IRV PNV 
ENA 
ERAP, dog 
EE waua [PERERA 


RUER: KUUA EE 
Ea AON 1 p 第 一 条 测试 信息 | 2006 年 10 月 23 日 20， 46: 38 


sle uu NA 


而 COO KA Fr 


图 20.8 论坛 首页 文件 首次 执行 结果 


20.4.2 ” 主 论 坛 显示 文件 的 创建 


主 论坛 是 论坛 分 类 数据 中 一 种 比较 特殊 的 类 型 。 它 代表 着 论坛 的 一 级 分 类 ， 在 它 的 下 面 还 有 更 详 
细 的 二 级 分 类 。 做 这 样 的 划分 是 为 了 更 详细 的 划分 论坛 结构 ， 如 一 个 普通 的 编程 论坛 可 能 包括 技术 区 、 
娱乐 区 等 内 容 。 其 中 的 技术 区 、 娱 乐 区 就 相当 于 主 论坛 , 而 技术 区 里 可 能 会 划分 为 PHP 编 程 区 、JavaScript 
编程 区 、MySQL 数据 库 编程 区 等 二 级 分 类 ;而 娱乐 区 也 可 能 会 分 为 灌水 区 、 贴 图 区 、 音 乐 电影 区 等 二 
级 分 类 。 

既然 论坛 有 这 样 的 多 级 分 类 划分 。 所 以 显示 主 论坛 及 其 下 的 分 论坛 是 很 有 必要 的 。 下 面 介绍 如 何 
用 PHP 代码 来 显示 主 论坛 。 

具体 内 容 参 考 以 下 代码 : 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 主 论坛 显示 </title>\n"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "<LINK href=\"style.css\" rel=stylesheet>\n"; 
echo "<center>\n"; 


if(!$_GETIid]) // 如 果 没有 参数 ， 则 显示 内 容 


echo "<h2> 没 有 请 求 I D</h2>"; 
echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 
exit(); 


} 
else // 如 果 存 在 参数 ， 则 显示 相应 论坛 
{ 

require "20-1.php"; 

$sql="select p_id from $table topic where id='$_GETI[id]"; 

$result=mysql_query($sql,$link) or die(mysql_error()); 

$rows=mysql_fetch_array($result); 
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if($rows[O]!=0) // 如 果 论 坛 不 是 主 论坛 
í 
echo "<h2> 请 求 的 ID 不 是 主 论坛 </h2>"; /显示 信息 
echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 
exit(); /中 止 所 有 PHP 执行 
} 
else // 如 果 是 主 论坛 ， 则 显示 HTML 
í 


echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>\n"; 

echo "<td>"; 

echo "<center><h2> 主 分 类 论坛 首页 </h2></center>"; 

echo "</td>\n"; 

echo "</tr>\n"; 

echo "</table>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>\n"; 

echo "<td><a href=20-5.php> 论 坛 首页 </a></td>\n"; 

echo "</tr>\n"; 

echo "</table>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>"; 
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echo "<td> 论 坛 </td><td> 贴 数 </td><td> 主 题 </td><td> 最 后 贴 标 题 </td><td> 最 后 贴 回 复 时 间 </td>\n"; 


echo "</tr>"; 
$sql="select * from $table topic where p_id='$_GET[id]"; 
$result=mysql_query($sql,$link) or die(mysql_error()); 
while($rows=mysql_fetch_array($result) /| 循环 显示 分 论坛 信息 
{ 
echo "<tr>\n"; 
echo "<td><a href=\"20-7.php?id=". $rows[id]."\">".$rows[topic_name]."</a><br>\n"; 
echo $rows[topic_description]."</td>\n"; 
echo "<td>". $rows[post_count]."</td>\n"; 
echo "<td>". $rows[post_m_count]."</td>\n"; 
$sql2="select id,title,post re time from $table posts where id='$rows[last_post_id] 
$result2=mysql_query($sql2,$link) or die(mysql_error()); 
$rows2=mysql_fetch_array($result2); /显示 最 后 一 条 贴 子 的 相关 信息 
echo "<td><a href=\"20-8.php?id=". $rows2[id]."\">".$rows2[title]."</a></td>\n"; 
echo "<td>". $rows2[post_re_time]."</td>\n"; 
echo "</tr>\n"; 
} 
echo "</table>\n"; 
echo "</center>\n"; 
echo "</body>\n"; 
echo "</html>\n"; 


ł 


?> 


把 以 上 代码 保存 为 “20-6.php”。 单 击 图 20.8 中 的 “默认 主 类 别 1” 链 接 ， 将 打开 20-6.php 并 且 带 


有 参数 ID=1。 其 执行 结果 如 图 20.9 所 示 。 
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图 20.9 主 论坛 显示 执行 结果 
与 20-5.php 不 同 的 是 ， 论 坛 首页 显示 文件 将 显示 所 有 主 分 类 论坛 及 其 下 面 的 分 论坛 的 信息 。 而 主 
论坛 显示 页 则 只 显示 本 类 分 论坛 的 信息 。 


2043 ”分 论坛 显示 文件 的 创建 


tt 


这 一 小 节 来 创建 分 论坛 的 显示 页 面 文件 。 该 文件 实现 的 作用 有 ， 显 示 当 前 分 类 论坛 下 的 贴 子 信息 ， 
其 包括 标题 、 作 者 、 查 看 、 回 复 、 最 后 发 表 等 内 容 。 下 面 就 通过 具体 的 代码 来 实现 分 论坛 页 面 的 显示 。 
具体 内 容 请 参看 以 下 代码 : 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 分 论坛 显示 </title>\n"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "<LINK href=\"style.css\" rel=stylesheet>\n"; 

echo "<center>\n"; 

if(I$_GET[id]) // 如 果 没 有 参数 ， 则 显示 内 容 


echo "<h2> 没 有 请 求 ID</h2>"; 
echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 
exit(); 


} 
else // 如 果 有 参数 提示 
{ 
require "20-1.php"; 
$sql="select p_id from $table topic where id='$_GET][id]""; 
$result=mysql_query($sql,$link) or die(mysql_error()); 
$rows=mysql_fetch_array($result); 


if($rows[0]==0) // 如 果 论坛 不 是 分 论坛 
echo "<h2> 请 求 的 ID 不 是 分 论坛 </h2>"; // 显 示 内 容 
echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 
exit(); 
} 
else /请求 ID 是 分 论坛 显示 HTML 


t 
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echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>\n"; 

echo "<td>"; 

echo "<center><h2> 分 论坛 首页 </h2></center>"; 

echo "</td>\n"; 

echo "</tr>\n"; 

echo "</table>\n"; 

$sql="select p_id from $table topic where id='$_GET[id]"; 
Sresult=mysql_query($sql,$link) or die(mysql_error()); 


$rows=mysql_fetch_array($result); /| 获取 主 论坛 ID 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>\n"; 
echo "<td><a href=20-5.php> 论 坛 首 页 </a>|<a href=20-6.php?id=".$rows[0]."> 主 论坛 </a>"; 
echo "</td>\n"; // 显 示 论坛 首页 及 主 论坛 连接 
if($_COOKIE[user]) /| 判断 用 户 是 否 登录 
{ 
echo "<td align=right><a href=20-8.php?topic_id=".$_GET[id]."> 发 表 新 主题 </a>"; 
echo "</td>\n"; // 如 果 用 户 已 经 登录 显示 发 贴 连接 
} 
echo "</tr>\n"; 


echo "</table>\n"; 
$sql="select id from $table posts where topic_id='$_GET[id] and re_id=0"; 


$result=mysql_query($sql,$link); // 获 取 主 题 数 
$nums=mysql_num_rows($result); /| 获取 主 题 总 数 
$p_count=ceil($nums/10); // 求 总 页 数 

if ($_GET["page"]==0 && !$_GETI"page"]) // 如 果 没 有 请 求 页 面 
$page=1; /当前 页 为 第 一 页 
else 

$page=$_GET[page]; /获取 当前 页 
$s=($page-1)*10+1; 

$s=$s-1; // 当 前 页 最 多 显示 数 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 

echo "<tr>"; 

echo "<td> 标 题 </td><td> 作 者 </td><td> 查 看 </td><td> 回 复 </td><td> 最 后 发 表 </td>\n"; 
echo "</tr>"; 


$sql="select * from $table posts where topic_id='$_GET[idj' and re id20 order by post re time 
desc limit $s, 10"; 
$result=mysql_query($sql,$link) or die(mysql_error()); 
while($rows=mysql_fetch_array($result)) /循环 显示 贴 子 信息 
{ 
echo "<tr>\n"; 
echo "<td><a href=\"20-8.php?id=". $rows[id]."\">".$rows[title]."</a></td>\n"; 
echo "<td>". $rows[poster]."</td>\n"; 
echo "<td>". $rows[view_count]."</td>\n"; 
echo "<td>". $rows[re_count]."</td>\n"; 
echo "<td>". $rows[post_re_time]."</td>\n"; 
echo "</tr>\n"; 
} 
echo "</table>\n"; 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
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echo "<tr>\n"; 

echo "<td>"; 

echo "<center>"; 

$prev_page=$page-1; /分 页 显示 前 一 页 

$next_page=$page+1; /定义 分 页 显示 下 一 页 

if ($page<=1) /如果 当 前 页 小 于 等 于 1 
echo "第 一 页 | "; 

} 

else 1/ 如果 当 前 页 大 于 1 
echo "<a href='$_SERVER[PHP_SELF]?page=1'> 第 一 页 </a> |" 

} 

if ($prev_page<1) /如 果 前 一 页 小 于 1 
echo "上 一 页 | "; 

else // 如 果 前 一 页 大 于 等 于 1 

{ 
echo "<a href='$_SERVER[PHP_SELF]?page=$prev_page'> 上 一 页 </a> | "; 

} 

if ($next_page>$p_count) /如 果 下 一 页 大 于 总 页 数 
echo "下 一 页 |" 

} 

else // 如 果 下 一 页 小 于 等 于 总 页 数 
echo "<a href='$_SERVER[PHP_SELF]?page=$next_page'> 下 一 页 </a> |" 

} 

if ($page>=$p_count) /| 如 果 当 前 页 大 于 等 于 总 页 数 
echo "最 后 一 页 </p>\n"; 

} 

else // 如 果 当 前 页 小 于 总 页 数 

{ 


echo "<a href='$_SERVER[PHP_SELF]?page=$p_count> 最 后 一 页 </a></p>\n"; 


echo "</center>"; 
echo "</td>\n"; 
echo "</tr>\n"; 
echo "</table>\n"; 
echo "</center>\n"; 
echo "</body>\n"; 
echo "</html>\n"; 


} 


?> 


将 上 面 的 代码 保存 为 “20-7.php”。 然 后 单 击 图 20.9 左下 方 的 默认 分 类 别 就 可 以 打开 分 论坛 显示 
文件 并 且 带 有 ID=2， 相 当 于 执行 20-7.php?id=2。 其 执行 结果 如 图 20.10 所 示 。 
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从 图 20.10 可 以 发 现 ， 显 示 出 了 本 类 论坛 的 所 有 主题 ， 并 且 显 示 了 主题 的 作者 、 查 看 次 数 、 回 复 次 


数 及 最 后 回复 时 间 。 
论坛 的 显示 部 分 就 介绍 到 这 里 。20.5 节 将 开始 介绍 用 户 如 何 发 表 新 主题 及 回复 已 经 存在 的 主 


20.5 主题 的 显示 与 回复 


题 。 


论坛 的 作用 就 是 用 户 之 间 就 某 一 主题 进行 讨论 ， 所 以 主题 的 显示 与 回复 是 论坛 所 有 实现 功能 中 的 


重 中 之 重 。 这 一 节 介绍 如 何 使 用 PHP 代码 实现 发 布 新 主题 ， 以 及 现 有 主题 的 显示 及 回复 功能 。 
20.5.1 发 表 新 的 主题 


发 表 新 的 主题 的 实现 方法 是 按照 用 户 的 输入 将 记录 添加 到 贴 子 数据 表 。 最 为 关键 的 一 项 是 其 
字段 要 为 0。 这 样 就 代表 该 条 贴 子 是 新 的 主题 了 。 
下 面 给 出 具体 代码 : 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 发 表 新 主题 </title>\n"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "<LINK href=\"style.css\" rel=stylesheet>\n"; 
echo "<center>\n"; 


if(!$_COOKIE[usen]) 1/ 用 户 没有 登录 的 非法 请 求 
{ 


echo "<h2> 匿 名 用 户 不 允许 发 贴 ! </h2>"; 
echo "<h3> 点 <a href=20-4.php> 这 里 </a> 登 录 </h3>"; 
exit(); 


} 
if(!$_GETI[topic id]) // 没 有 分 论坛 参数 
{ 

echo "<h2> 没 有 请 求 ID</h2>"; 


echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 
exit(); 


re id 
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// 如 果 有 请 求 分 论坛 ID 


require "20-1.php"; 

$sql="select p id from $table topic where id-'$ GETItopic id)"; 
$result=mysql_query($sql,$link) or die(mysql_error()); 
$rows=mysql_fetch_array($result); 

if($rows[0]==0) // 如 果 请 求 ID 不 是 分 论坛 


echo "<h2> 请 求 的 ID 不 是 分 论坛 </h2>"; 
echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 


exit(); 
} 
else // 如 果 是 分 论坛 
if(!$_POST{[title]) // 如 果 没有 提交 变量 ， 则 显示 前 台 


if(!$_GET[re_id]) $re_id=0; // 如 果 没有 回复 ID 号 
else $re_id=$_GET[re id); /获取 回复 ID 号 
echo "<script language=\"javascript\">\n"; 

echo "function juge(theForm)\n"; 

echo "An"; 

echo "\tif (theForm.title.value == \"\")\n"; 

echo "Win"; 

echo "ttalert(\" 请 输入 主题 名 称 ! Van 

echo "tttheForm .title.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "Min"; 

echo "tif (theForm.content.value == \"\")\n"; 

echo "itin"; 

echo "ttalert(\" 请 输入 主题 内 容 ! \")\n"; 

echo "\t\ttheForm.content.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "tjn"; 

echo "Jn"; 

echo "</script>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>\n"; 

echo "<td>"; 

echo "<center><h2>"; 

if($re_id==0) echo "发 表 新 主题 "; 

else echo "发 表 回复 "; 

echo "</h2></center>"; 

echo "</td>\n"; 

echo "</tr>\n"; 

echo "</table>\n"; 

$sql="select p id,topic name from $table topic where id-'$ GETItopic id)"; 
$result=mysql_query($sql,$link) or die(mysql_error()); 
$rows=mysql_fetch_array($result); 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
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echo "<tr>\n"; 
echo "<td><a href=20-5.php> 论 坛 首页 </a>|<a href=20-6.php?id=".$rows[0]."> 主 论坛 </a>|<a 


href=20-7.php?id=".$_GET[topic_id].">".$rows[1]."</a></td>\n"; 


echo "</tr>\n"; 

echo "</table>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 

echo "<form method=\"post\" action=\"20-8.php?topic_id=".$_GET[topic_id]."\" 


onsubmit=\"return juge(this)\">\n"; 


echo "<input type=hidden name=re_id value=".$re_id.">"; 

echo "<tr>\n"; 

echo "<td> 输 入 标题 : </td>\n"; 

echo "<td><input type=text name=title></td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 输 入 内 容 : </td>\n"; 

echo "<td><textarea rows=5 cols=50 name=content></textarea></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td colspan=\"2\"><center><input type=submit value= 提 交 ><input type=reset value= 重 置 


></center></td>\n"; 


echo "</tr>\n"; 
echo "<form>"; 
echo "</table>\n"; 
echo "</center>\n"; 
echo "</body>\n"; 
echo "</html>\n"; 


// 后 台 处 理 


Stitle=$_POSTItitle]; // 获 取 参 数 

$content=$_POST[content]; 

$re_id=$_POST[re_id]; 

Stopic id-$ GETItopic id); 

$ip=$_SERVER[REMOTE_ADDR]; 

$time=date("Y 4 m A d A G: i: s"); 

$sql="select id,nickname from $table_members where name='$_COOKIE[usen "; 
Sresult=mysql_query($sql,S$link); 

$rows=mysql_fetch_array( $result); 

$sql="insert into 


$table posts(topic id,re id,poster id,poster ip,poster,title,content,post time,post re time)values('$topic id','$r 
e id','$rows|0)','$ip',"Srows|nicknamej)','$title','$content','$time','$time')"; 


if(mysql_query($sql,$link) or die(mysql_error())) 


if($re_id==0) // 如 果 是 发 表 主 题 的 操作 
í 
$sql="select max(id) from $table posts"; 
Sresult=mysql_query($sql,S$link); 
$rows=mysql_fetch_array($result); 
echo $rows[0]; 
$sql="update $table_posts set re_count=re_count+1,post_re_time='$time' where 
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id='$topic_ id"; 
mysql_query($sql,$link); 
} 
else // 如 果 是 发 表 回 复 的 操作 
{ 
$sql="update $table posts set re_count=re_count+1 where id='$topic_ id"; 
mysql_query($sql,$link); 
} 
$sql="update $table topic set post_count=post_count+1 where id-'$topic id'"; 
mysql_query($sql, $link); 
$sql="update $table topic set post_count=post_count+1 where id='$tipic_id"; 
mysql_query ($sql,$link); 
echo "添加 记录 成 功 ， 现 在 返回 分 论坛 页 "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=20-7.php?id=".$topic_id."\">"; 
} 
else 
{ 
echo "添加 记录 时 出 错 ， 现 在 返回 "; 
echo "<meta http-equiv=\"refresh\" content=\"2; ur=20-7.php?id=". $topic_id."\">"; 
} 
} 
F 
} 
?> 


把 以 上 代码 保存 为 “20-8.php”。 单 击 图 20.10 中 “发 表 新 主题 ”的 链接 就 相当 于 执行 20-8.php， 
其 执行 结果 如 图 20.11 所 示 。 按 照 要 求 填 入 标题 及 内 容 。 单 击 “ 提 交 ” 按 钮 就 可 以 发 表 新 的 主题 了 。 当 
主题 成 功 发 布 后 ， 程 序 会 自动 跳 转 到 相应 的 子 分 类 页 面 中 ， 如 图 20.12 所 示 。 
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图 20.11 发 表 新 主题 执行 结果 图 20.12 成 功 发 布 新 主题 执行 结果 


这 样 新 的 主题 就 成 功 添 加 到 贴 子 的 表 中 了 。 主 题 成 功 入 库 还 是 不 够 的 ， 必 须要 让 浏览 者 能 够 浏览 
才 行 。20.5.2 小 节 介 绍 如 何 显 示 已 经 存在 主题 。 


20.5.2 ” 现 有 主题 的 显示 


这 一 小 节 来 讲解 如 何 显示 已 经 存在 的 主题 。 主 题 的 显示 也 很 简单 ， 首 先 获 取 用 户 提 交 的 ID， 然 后 
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判断 该 ID 所 对 应 的 贴 子 是 否 是 主题 。 因 为 贴 子 存在 主题 与 主题 的 回复 两 种 情况 , 所 以 要 做 这 样 的 判断 。 


如 果 提 交 的 ID 不 是 主题 则 给 出 相应 提示 ， 如 果 是 主题 ， 则 显示 该 主题 内 容 及 对 于 该 主题 的 


回复 。 


这 里 涉及 到 对 多 个 表 的 查询 与 读 取 。 既 要 读 取 贴 子 相关 内 容 ， 也 要 读 取 贴 子 对 应 的 分 类 数据 表 记 
录 的 读 取 。 另 外 ， 在 浏览 主题 的 同时 要 记得 每 请 求 一 次 主题 显示 文件 ， 就 要 给 主题 的 浏览 次 数 即 


view count 增加 1。 这 样 才能 准确 的 获得 主题 的 浏览 次 数 。 
下 面 给 出 主题 显示 的 详细 代码 : 


<?php 
echo "<html>\n"; 
echo "<head>\n"; 
echo "<title> 显 示 主 题 </title>\n"; 
echo "</head>\n"; 
echo "<body>\n"; 
echo "<LINK href=\"style.css\" rel=stylesheet>\n"; 
echo "<center>\n"; 
if(!$_GET[id]) // 如 果 没 有 请 求 主题 ID 
1 
echo "<h2> 没 有 请 求 ID</h2>"; 
echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 
exit(); 
} 
else // 显 示 主 题 内 容 
í 
require "20-1.php"; 
$sql="select * from $table posts where id='$_GET[id]"; 
$result=mysql_query ($sql, $link); 
$rows=mysql_fetch_array($result); 
if($rows[re_id]!=0) // 如 果 请 求 ID 不 是 主题 


echo "<h2> 请 求 的 贴 子 不 是 主题 ! </h2>"; 
echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 


exit(); 
} 
else 
{ 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>\n"; 
echo "<td>"; 
echo "<center><h2> 主 题 显示 </h2></center>"; 
echo "</td>\n"; 


echo "</tr>\n"; 

echo "</table>\n"; 

$sql2="select id,p_id,topic_name from $table topic where id-'$rowsltopic id)"; 
$result2=mysql_query($sql2,$link); 

$rows2=mysql_fetch_array($result2); 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 

echo "<tr>\n"; 


echo "<td><a href=20-5.php> 论 坛 首 页 </a>|<a href=20-6.php?id=".$rows2[1]."> 主 论坛 </a>|<a 
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href=20-7.php?id=".$rows2[0].">".$rows2[2]."</a>"; 


} 


?> 


echo "</td>\n"; 


echo "<td align=right><a href=20-8.php?topic id=".$rows2[0]."> 发 表 新 主 </a>|<a 
href=20-8.php?topic_id=".$rows2[0]."&re_id=".$_GET[id]."> 发 表 回复 </a>"; 


echo "</td>\n"; 
echo "</tr>\n"; 
echo "</table>\n"; 


echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 


echo "<tr>\n"; 
echo "<td>\n"; 


echo "作者 : ".$rows[poster]; 


echo "<br> 作 者 ID: ".$rows[poster_id]; 
echo "<br> 作 者 IP: ".$rows[poster_ip]; 
echo "<br> 标 题 : ".$rows[title]; 

echo "<br> 内 容 : ".$rows[content]; 

echo "<br> 发 表 时 间 : ".$rows[post_time]; 


echo "</td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 


echo "<td> 以 下 为 该 主题 的 回复 </td>\n"; 


echo "</tr>\n"; 


$sql="select * from $table posts where re_id='$_GETI[id]"; 
Sresult=mysql_query($sql,$link); 
while($rows=mysql_fetch_array($result) 


{ 
echo "<tr>\n"; 
echo "<td>\n"; 
echo "作者 : ".$rows[poster]; 
echo "<br> 作 者 ID: ".$rows[poster_id]; 
echo "<br> 作 者 IP: ".$rows[poster_ip]; 
echo "<br> 标 题 :".$rows[title]; 
echo "<br> 内 容 :".$rows[content]; 
echo "<br> 发 表 时 间 :".$rows[post_time]; 
echo "</td>\n"; 
echo "</tr>\n"; 

} 


$sql="update $table posts set view_count=view_count+1 where $id='$_GET[id]"; 


mysql_query($sql, $link); 
echo "</table>\n"; 

echo "</center>\n"; 
echo "</body>\n"; 

echo "</html>"; 


把 以 上 代码 保存 为 “20-9.php”。 单 击 图 20.12 中 贴 子 标题 的 链接 就 可 以 进入 相应 的 主题 显示 页 面 
了 。 单 击 “ 第 一 条 测试 信息 ”链接 ， 如 图 20.13 所 示 。 
从 图 20.13 可 以 发 现 , 程序 正确 的 显示 出 了 相应 主题 及 发 贴 者 的 相关 信息 。 下 面 介绍 如 何 对 主题 进 
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图 20.13 主题 显示 执行 结果 
20.5.3 ”主题 的 回复 


对 主题 进行 回复 ， 只 需要 给 20-8.php 加 上 相应 的 参数 即 可 实现 。 在 编写 20-8.php 时 曾 用 到 这 样 的 
参数 re_id。 当 该 参数 为 0 时 ， 表 示 发 表 新 的 主题 ， 而 当 该 值 为 某 数 值 时 说 明 是 对 ID 号 为 该 值 的 主题 
进行 回复 。 在 这 里 直接 调用 即 可 实现 对 主题 的 回复 。 

不 过 回复 的 操作 并 不 只 是 把 用 户 输入 记录 添加 进 表 就 行 了 ， 还 要 进行 一 系列 的 操作 ， 如 使 分 类 表 
中 相应 的 记录 的 贴 子 数 自 增 1、 使 相应 用 户 的 发 贴 数 自 增 1 和 相应 主题 的 回复 数 自 增 1 等 。 

单 击 图 20.13 中 的 “发 表 回 复 ”链接 ， 将 打开 20-8.php。 不 过 不 同 的 是 已 经 不 是 发 表 新 主题 了 ， 而 
是 回复 主题 了 。 填 写 相 应 的 标题 及 内 容 ， 提 交 回复 后 ， 将 回 到 分 论坛 页 ， 单 击 回复 的 主题 以 查看 回复 
是 否 正 确 显示 ， 执 行 结果 如 图 20.14 所 示 。 

EE mii 
Ka MED EEV kwa) IRD Whw -4 


SEM 


LAMI BSS KUN I ZIDI BEDA 


RPE. dog ham, test 


发 表 时 | WE test 


AP doa |m, 
AEI ooa | 村 可， 对 TEST 的 


2006 年 19 有 23 晶 
RER. 


作 老 IP， 
PEEN Am ERARA. 


200651093249 a 
Ile 32, 23 

m zl 
= COO eme gi 


20.14 回复 过 的 主题 显示 页 执行 结果 


ka PHP 网 络 编程 从 入 门 到 精通 


显示 回复 时 , 只 需要 把 回复 内 容 跟 在 主题 后 面 即 可 。 从 图 20.14 可 以 看 出 正确 的 显示 了 已 经 存在 的 
主题 内 容 及 相应 的 回复 。 

关于 主题 贴 子 的 显示 与 回复 ， 这 一 节 就 介绍 到 这 里 。 接 下 来 的 几 节 重 点 介绍 管理 员 或 者 版 主 才 有 
的 权限 的 内 容 ， 如 对 整个 论坛 分 类 的 管理 、 对 贴 子 的 管理 等 内 容 。 


20.6 ”论坛 分 类 的 管理 


系统 在 进行 安装 的 时 候 创建 了 默认 的 主 类 别 及 分 类 别 ， 但 这 对 于 一 个 通用 的 论坛 来 说 是 远 远 不 够 
的 。 应 该 给 予 管理 员 相 应 的 权限 ， 以 创建 新 的 类 别 。 这 一 节 就 来 讲 讲 如 何 对 论坛 的 分 类 进行 管理 ， 殿 
中 包括 为 论坛 增加 新 的 类 别 ， 及 更 改 现 有 的 类 别 。 通 常情 况 下 ， 一 个 论坛 分 类 在 创建 后 就 不 能 被 删除 
了 ， 所 以 就 不 再 讨论 如 何 删除 分 类 的 问题 。 


20.6.1 为 论坛 增加 新 的 类 别 


为 论坛 增加 类 别 包括 两 种 情况 : 一 种 是 增加 主 分 类 即 主 论坛 ， 一 种 是 为 某 一 存在 的 主 分 类 增加 二 
级 分 类 即 分 论坛 。 在 有 些 比较 大 型 的 论坛 程序 中 ， 甚 至 还 有 三 级 或 者 多 级 的 分 类 。 这 里 只 探讨 二 级 的 
情况 。 

为 论坛 增加 新 的 类 别 的 操作 分 几 步 进行 。 第 1 步 先 让 用 户 选择 欲 创 建 的 类 别 是 主 类 别 还 是 分 类 别 。 
第 2 步 ， 如 果 用 户 选择 的 是 主 类 别 ， 在 这 一 步 直接 输入 类 别名 称 及 介绍 等 相应 信息 即 可 ; 如 果 用 户 在 
第 1 步 选择 的 是 分 类 别 ， 则 还 需要 让 用 户 选择 ， 该 分 类 属于 已 经 存在 的 哪 一 个 主 类 别 。 然 后 再 按照 选 
择 输入 类 别名 称 、 类 别 说 明 等 内 容 。 

下 面 给 出 具体 的 代码 : 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 增 加 新 论坛 </title>\n"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "<LINK href=\"style.css\" rel=stylesheet>\n"; 
echo "<center>\n"; 

require "20-1.php"; 

$sql="select admin from $table members where name-'$ COOKIE|user)"; 
Sresult=mysql_query($sql,$link); 
$rows=mysql_fetch_array($result); 
if($rows['admin']<3) 

{ 


echo "<h2> 你 没有 这 项 权限 来 运行 该 文件 ! </h2>"; 
echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 
exit(); 

} 


else 
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{ 

if(!$_POST[topic]) 

{ 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<form method=\"post\" action=\"".$_SERVER[PHP_SELF]."\">\n"; 
echo "<tr>\n"; 
echo "<td colspan=\"2\"><center><h2> 创 建 论坛 分 类 第 一 步 </h2></center></td>\n"; 
echo "</tr>"; 
echo "<tr>\n"; 
echo "<td> 选 择 创 建 类 别 </td>\n"; 
echo "<td>"; 
echo "<select size=\"1\" name=\"topic\">\n"; 
echo "<option value=\"1\"> 主 类 别 </option>\n" 
echo "<option value=\"2\"> 分 类 别 </option>\n"; 
echo "</select>\n"; 
echo "</td>\n"; 
echo "</tr>"; 
echo "<tr>\n"; 
echo "<td colspan=\"2\"><center><input type=submit value=\" 下 一 步 \"></td>\n"; 
echo "</tr>\n"; 
echo "</form>\n"; 
echo "</table>\n"; 
echo "</center>\n"; 
echo "</body>"; 
echo "</html>\n"; 

$ 

else if(!$_POST[topic_name]) 

{ 
echo "<script language=\"javascript\">\n"; 
echo "function juge(theForm)\n"; 
echo "An"; 
echo "if (theForm.topic_name.value == \"\")\n"; 
echo "Win"; 
echo "ttalert(\" 请 输入 类 别名 称 ! \");\n"; 
echo "\t\ttheForm.topic_name.focus();\n"; 
echo "\t\treturn (false);\n"; 
echo \t}\n"; 
echo "tif (theForm.topic description.value == \"\")\n"; 
echo "Win"; 
echo "\t\talert(\" 请 输入 类 别 介绍 ! "An"; 
echo "\t\ttheForm.topic_description.focus();\n"; 
echo "\t\treturn (false);\n"; 
echo "Min"; 
echo "An"; 
echo "</script>\n"; 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<form method=\"post\" action=\"".$_SERVER[PHP_SELF]."\" onsubmit=\"return 

juge(this) "An"; 

echo "<tr>\n"; 


echo "<td colspan=\"2\"><center><h2> 创 建 论坛 分 类 第 二 步 </h2></center></td>\n"; 
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echo "</tr>"; 
echo "<input type=\"hidden\" name=\"topic\" value=\"".$_POST[topic]."\">"; 
if($_POST[topic]==2) 


{ 
echo "<tr>\n"; 
echo "<td> 选 择 分 类 别 所属 主 类 </td>\n"; 
echo "<td>"; 
echo "<select size=\"1\" name=\"p_id\">\n"; 
$sql="select id,topic_name from $table_topic where p_id=0"; 
Sresult=mysql_query($sql,S$link); 
while($rows=mysql_fetch_array($result)) 
{ 
echo "<option value=\"". $rows[id]."\">". $rows[topic_name]."</option>\n"; 
i 
echo "</select>\n"; 
echo "</td>\n"; 
echo "</tr>"; 
} 


echo "<tr>\n"; 

echo "<td> 输 入 类 别名 称 </td>\n"; 

echo "<td>"; 

echo "<input type=\"text\" name=\"topic_name\">\n"; 

echo "</td>\n"; 

echo "</tr>"; 

echo "<tr>\n"; 

echo "<td> 输 入 类 别 介绍 </td>\n"; 

echo "<td>"; 

echo "<input type=\"text\" name=\"topic_description\">\n"; 

echo "</td>\n"; 

echo "</tr>"; 

echo "<tr>\n"; 

echo "<td colspan=\"2\"><center><input type=button value=" 上 一 # V 
onclick=\"history.go(-1)\"><input type=submit value=\" 下 一 步 \*></td>\n"; 

echo "</tr>\n"; 

echo "</form>\n"; 

echo "</table>\n"; 

echo "</center>\n"; 

echo "</body>"; 

echo "</html>\n"; 


else 


$topic=$_POSTI[topic]; 
$topic_name=$_POSTI[topic_name]; 
$topic_description=$_POSTI[topic_description]; 
if($topic==2) 


S$p_id=$_POSTIp_id]; 
} 
$sql="insert into 
$table_topic(p_id,topic_name,topic_description)values('$p_id','$topic_name','$topic_description')"; 
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if(mysql_query($sql,$link)) 


echo "增加 新 论坛 操作 成 功 ， 现 在 返回 首页 !"; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=20-5\">"; 


} 
else 
echo "增加 新 论坛 操作 失败 ， 现 在 返回 ! "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=20-10\">"; 
} 
} 
} 
?> 


把 以 上 代码 保存 为 “20-10.php”。 直 接 在 PHP 执行 环境 下 运行 该 文件 。 如 果 没 有 相应 的 权限 ， 则 
会 出 现 如 图 20.15 所 示 的 提示 ， 而 如 果 已 经 以 管理 员 身 份 进行 登录 ， 重 新 执行 该 PHP 文件 ， 其 执行 结 
果 会 如 图 20.16 所 示 。 
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图 20.15 无 权限 时 执行 增加 类 别 文件 执行 结果 图 20.16 ”以 管理 员 身 份 执行 添加 操作 第 1 步 

这 一 步 很 简单 ， 只 需要 选择 相应 的 类 别 即 可 ， 这 里 选择 创建 分 类 别 ， 然 后 单 击 “ 下 一 步 ” 按 钮 则 
会 出 现 如 图 20.17 所 示 的 画面 。 

由 于 要 创建 的 是 分 类 别 ， 所 以 要 选择 分 类 别 所 属 的 主 类 别 。 但 目前 论坛 分 类 数据 表 中 只 有 一 个 主 
类 别 ， 所 以 不 用 选择 ， 然 后 输入 类 别 相应 名 称 ， 及 简单 介绍 即 可 。 单 击 “ 下 一 步 ”按钮 ， 如 果 成 功 执 
行 的 话 ， 程 序 会 在 执行 完 相 应 的 操作 后 直接 跳 转 到 论坛 的 首页 。 也 可 以 通过 首页 的 显示 ， 查 看 是 否 添 
加 成 功 。 如 图 20.18 所 示 是 执行 结果 。 
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20.17 ”以 管理 员 身份 执行 添加 操作 第 2 步 20.18 ”成 功 添加 相应 类 别 后 的 首页 
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比较 图 20.18 与 图 20.8 TURM: 第 1 个 分 类 别 的 贴 子 除 在 数量 上 有 区 别 之 外 还 有 一 个 区 别 就 是 
多 出 了 一 个 新 的 分 类 别 。 说 明 添 加 操作 成 功 执行 。 


有 一 点 要 引起 注意 ， 由 于 用 


户 发 贴 都 是 基于 分 类 别 发 贴 的 ， 所 以 如 果 一 个 主 类 别 下 边 没 有 相应 的 


分 类 别 ， 它 是 不 会 被 显示 的 。 所 以 ， 在 添加 完 一 个 主 类 别 后 必须 为 其 添加 相应 的 分 类 别 。 


20.6.2 ”更改 现 有 类 别 


论坛 的 分 类 在 创建 后 不 能 一 成 不 变 。 最 起 码 在 创建 初期 应 该 会 有 改变 ， 如 系统 默认 的 类 别 并 不 符 
合用 户 使 用 的 要 求 ， 所 以 就 要 改变 相应 类 别 的 名 称 或 者 类 别 简介 等 内 容 。 这 一 小 节 介绍 对 现 有 类 别 的 


修改 操作 。 


由 于 某 一 类 别 的 主题 数 及 贴 子 数 这 些 属性 是 动态 生成 的 ， 并 与 论坛 的 贴 子 数据 表 是 紧密 相连 的 ， 
所 以 ， 不 能 修改 这 些 内 容 。 只 能 修改 类 别名 称 、 类 别 简介 及 分 类 别 所属 主 类 这 些 内 容 。 


下 面 给 出 具体 的 操作 代码 : 


<?php 
echo "<html>\n"; 
echo "<head>\n"; 


echo "<title> 修 改 已 有 的 论坛 </title>\n"; 


echo "</head>\n"; 
echo "<body>\n"; 


echo "<LINK href=\"style.css\" rel=stylesheet>\n"; 


echo "<center>\n"; 
require "20-1.php"; 


$sql="select admin from $table members where name='$_COOKIE[user]"; 
$result=mysql_query($sql,$link); 
$rows=mysql_fetch_array($result); 


if($rows[admin]<3) 


echo "<h2> 您 没有 这 项 权限 来 运行 该 文件 ! </h2>"; 
echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 


exit(); 

} 

else 
if(!$_POSTI[id]) 
{ 


echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<form method=\"post\" action=\"".$_SERVER[PHP_SELF]."\">\n"; 


echo "<tr>\n"; 


echo "<td colspan=\"4\"><center><h2> 修 改 论坛 第 一 步 </h2></center></td>\n"; 


echo "</tr>"; 
echo "<tr>\n"; 


echo "<td> 选 择 论坛 </td>\n"; 
echo "<td> 主 /分 </td>\n"; 

echo "<td> 论 坛 名 称 </td>\n"; 
echo "<td> 论 坛 简介 </td>\n"; 


3 
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echo "</tr>"; 

$sql="select id,p_id,topic_name,topic_description from $table topic", 

$result=mysql_query($sql,$link); 

while($rows=mysql_fetch_array($result) 

£ 
echo "<tr>\n"; 
echo "<td><input type=\"radio\" name=\"id\" value=\"".$rowsļid]."\"></td>\n"; 
echo "<td>". 
if($rows[p_id]==0) 
{ 


echo " 主 论坛 "; 


echo "分 论坛 "; 
} 
echo "</td>\n"; 
echo "<td>". $rows[topic_name]."</td>\n"; 
echo "<td>". $rows[topic_description]."</td>\n"; 
echo "</tr>\n"; 
} 
echo "<tr>\n"; 
echo "<td colspan=\"4\"><center> <input type=submit value=\" 下 一 步 \"></td>\n"; 
echo "</tr>\n"; 
echo "</form>\n"; 
echo "</table>\n"; 
echo "</center>\n"; 
echo "</body>"; 
echo "</html>\n"; 


else if(!$_POST[topic_name]) 


{ 


echo "<script language=\"javascript\">\n"; 

echo "function juge(theForm)\n"; 

echo "An"; 

echo "tif (theForm.topic_name.value == \"\")\n"; 
echo "Win"; 

echo ttalert" 请 输入 类 别名 称 ! An"; 

echo "\t\ttheForm.topic_name.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "Min"; 

echo "\tif (theForm.topic_description.value == \"\")\n"; 
echo "Win"; 

echo "\t\talert(\" 请 输入 类 别 介 绍 ! \");\n"; 

echo "\t\ttheForm.topic_description.focus();\n"; 
echo "\t\tretum (false);\n"; 

echo "Min"; 

echo "An"; 
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echo 
echo 
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juge(this)\">\n"; 
echo 
echo 
echo 
echo 
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"</script>\n"; 
"<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 


"<form method=\"post action=\"".$_SERVER[PHP_SELF]."\" onsubmit=\"return 


"<tr>\n"; 
"<td colspan=\"2\"><center><h2> 创 建 论坛 分 类 第 二 步 </h2></center></td>\n"; 
nap; 


"<input type=\"hidden\" name=\"id\" value= 


POSTIdl >"; 


$sql="select * from $table topic where id='$_POST[id]"; 
Sresult=mysql_query($sql,$link); 
$rows=mysql_fetch_array($result); 

if($rows[p_id]!=0) 


{ 


} 

echo 
echo 
echo 
echo 
echo 
echo 
echo 
echo 
echo 
echo 
echo 
echo 
echo 
echo 


echo "<tr>\n"; 

echo "<td> 选 择 分 类 别 所属 主 类 </td>\n"; 

echo "<td>"; 

echo "<select size=\"1\" name=\"p_id\">\n"; 

$sql2="select id,topic_name from $table_topic where p_id=0"; 

$result2=mysql_query($sql2,$link); 

while($rows2=mysql_fetch_array($result2)) 

{ 
echo "<option value=\".$rows2[id]; 
if($rows2[id]==$rows[p_id]) echo " checked "; 
echo "\">".$rows2[topic_name]."</option>\n"; 

} 

echo "</select>\n"; 

echo "</td>\n"; 

echo "</tr>"; 


"<tr>\n"; 

"<td> 输 入 类 别名 称 </td>\n"; 

"<td>"; 

"<input type=\"text\" name=\"topic_name\" value=\"".$rows[topic_name]."\">\n"; 
"</td>\n"; 

nao; 

"<tr>\n"; 

"<td> 输 入 类 别 介绍 </td>vn'"; 

"<td>"; 

"<input type=\"text\" name=\"topic_description\" value=\"".$rows[topic_description].\">\n"; 
"</td>\n"; 

nat; 

"<tr>\n"; 


"<td colspal "><center><input type=button value=" 上 一 步 


onclick=\"history.go(-1)\"><input type=submit value=\" 下 一 步 \*></td>\n"; 


echo 
echo 
echo 
echo 
echo 


"</tr>\n"; 
"</form>\n"; 
"</table>\n"; 
"</center>\n"; 
"</body>"; 


y 
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echo "</html>\n"; 

} 

else 

{ 
$id=$_POSTIid]; 
$topic=$_POST[topic]; 
$topic_name=$_POST[topic_name]; 
$topic_description=$_POST[topic_description]; 
if($_POST[p id)) 
{ 


$p_id=$_POST[p_id]; 


else 
{ 
$p_id=0; 
} 
$sql="update $table_topic set 
p_id='$p_id',topic_name='$topic_name",topic_description='$topic_description' where id=$id"; 
if(mysql_query($sql,$link)) 


echo "修改 论坛 操作 成 功 ， 现 在 返回 首页 ! "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=20-5\">"; 


} 
else 
echo "修改 论坛 操作 失败 ， 现 在 返回 !"; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=20-10\">"; 
} 
} 
} 
?> 


将 上 述 代码 保存 为 “20-11.php”。 与 增加 新 类 别 操作 一 样 ， 如 果 没 有 相应 的 权限 ， 执 行 该 文件 将 
出 现 如 图 20.15 一 样 的 提示 。 如 果 以 管理 员 身份 运行 该 文件 ， 其 执行 结果 将 如 图 20.19 所 示 。 

这 里 显示 出 了 目前 论坛 中 的 所 有 一 级 论坛 及 二 级 论坛 。 选 中 前 面 的 单 选 按钮 以 选择 相应 的 记录 进 
行 操作 。 这 里 选择 对 默认 分 类 别 进 行 修 改 操 作 。 选择 好 后 ， 单 击 “ 下 一 步 ” 按钮， 将 出 现 图 20.20 所 示 
的 执行 结果 。 
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图 20.19 以 管理 员 身 份 执行 修改 操作 第 一 步 20.20 ”以 管理 员 身 份 执行 修改 操作 第 二 步 
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从 图 20.20 可 以 看 出 ， 这 里 能 够 对 分 类 别 的 所 属 主 类 别 ( 如 果 操作 的 是 主 类 别 将 没有 这 一 项 ) 、 类 
别名 称 、 类 别 介绍 等 内 容 进 行 修改 。 这 里 把 类 别名 称 更 改 为 “PHP 编程 ”， 类 别 介绍 修改 为 “PHP 编 
程 专区 ， 欢 迎 各 位 PHP 菜鸟 大 虾 光临 ! ”。 由 于 现在 只 有 一 个 主 类 别 ， 所 以 主 类 别 必须 选择 “默认 主 
类 别 1” 选 项 。 然 后 单 击 “ 下 一 步 ” 按 钮 ， 如 果 操 作成 功 ， 程 序 将 自动 跳 转 到 论坛 首页 ， 如 图 20.21 
所 示 。 

从 图 20.21 可 以 看 出 相应 的 类 别 已 经 被 修改 了 。 同 理 , 也 可 以 对 主 类 别 或 者 其 他 所 有 类 别 进行 相应 
修改 。 下 面 把 “默认 的 主 类 别 1” 修 改 为 “网 络 编程 区 ”， 把 类 别 介绍 修改 为 “网 络 语言 编程 区 : 有 
PHP, ASP, JavaScript 等 内 容 ”。 修 改 后 的 结果 如 图 20.22 所 示 。 
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图 20.21 成 功 修改 相应 类 别 后 的 首页 20.22 主 类 别 修改 之 后 的 首页 显示 效果 


通常 情况 下 ， 不 需要 对 论坛 分 类 进行 删除 操作 ， 所 以 这 里 要 介绍 的 论坛 分 类 就 不 再 探讨 分 类 的 删 
除 问题 。 至 此 ， 论 坛 分 类 管理 就 为 读者 介绍 完毕 。 从 这 两 节 的 介绍 可 以 看 出 ， 对 分 类 的 管理 ， 实 际 上 
还 是 对 数据 库 表 的 添加 或 者 修改 操作 ， 只 要 明白 其 中 的 道理 ， 一 切 都 变 得 很 简单 。 


20.7” 贴 子 的 管理 


这 一 节 介绍 对 论坛 中 贴 子 的 管理 。 贴 子 是 构成 论坛 的 灵魂 ， 论 坛 只 有 有 了 好 贴 子 才能 发 挥 其 生命 
力 。 那 些 广告 贴 、 垃 圾 贴 、 含 有 不 合法 内 容 的 贴 子 要 及 时 清除 。 这 一 节 的 内 容 就 是 如 何 对 贴 子 进 行 管 
理 。 其 中 包括 贴 子 的 编辑 、 非 法 贴 的 删除 和 如 何 防 止 用 户 恶 意 掘 墓 等 内 容 。 


20.7.1 编辑 贴 子 


用 户 发 的 贴 中 ， 有 时 会 有 一 些 不 合适 的 内 容 ， 或 者 用 户 发 错 的 内 容 ， 这 就 应 该 给 管理 员 和 贴 子 的 
作者 有 编辑 贴 子 内 容 的 权限 。 这 里 要 对 显示 贴 子 的 页 面 (20-9.php) 做 一 定 改动 。 给 相应 的 贴 子 上 显示 
出 编辑 链接 。 当 用 户 有 编辑 权限 时 〈 这 里 有 两 种 情况 ， 一 种 是 用 户 本 身 是 论坛 管理 员 或 者 相应 区 的 版 
主 ; 另 一 种 是 这 条 贴 子 的 作者 就 是 浏览 的 用 户 ) ， 显 示 该 编辑 链接 ， 反 之 不 显示 。 这 样 ， 就 可 以 实现 
贴 子 的 编辑 了 。 

具体 怎么 改动 呢 ? 

下 面 给 出 具体 的 代码 。 
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分 别 找到 显示 主题 与 回复 代码 中 的 这 样 的 内 容 


echo "<td>"; 
echo "标题 :".$rowsltitle]; 
echo "</td>"; 


把 上 面 的 内 容 修改 如 下 : 


echo "<td>"; 

echo "标题 : ".$rows[title]; 

if($rows[poster]==$_COOKIE[user]) 1/ 判断 用 户 与 贴 子 作者 是 否 是 同一 人 
echo" <a href=\"20-12.php?id=".$rows[id]."\"> 编 辑 </a>"; 

echo "</td>"; 
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这 样 当 浏览 的 用 户 与 发 贴 〈 或 者 回复 ) 的 作者 是 同一 个 人 的 话 ， 就 是 在 贴 子 或 者 回复 的 标题 后 会 


显示 出 “编辑 ”的 链接 ， 以 方便 用 户 对 贴 子 实现 编辑 操作 。 
也 可 以 这 样 : 


echo "<td>"; 

echo "标题 : ".$rows[title]; 

$sql_t="select admin from $table members where name='$_COOKIE[usen "; 
$result_ t=mysql_query($sql_t,$link); 

$rows_t=mysql_fetch_array($result_1); 

if($rows_t[admin]==3) 

echo" <a href=\"20-12.php?id=".$rows[id]."\"> 编 辑 </a>"; 

echo "</td>"; 


上 面 的 修改 是 让 管理 员 也 有 编辑 贴 子 的 权限 ， 与 普通 用 户 不 同 。 普 通用 户 只 能 修改 自己 所 发 的 贴 


子 ， 而 管理 员 则 可 以 修改 所 有 的 贴 子 。 
经 过 以 上 修改 ， 再 次 运行 20-9.php 时 的 执行 结果 会 如 图 20.23 所 示 。 


Io SaD SEV SRW I 


论坛 首页 | 主 论坛 |PHP 沉 程 。  。 发表 新 主题 | 发表 回复 | 

作者 .doa| 

作者 ID 1 

$. dog 

BP |F testit 

bo | z| 
[Ol Cr E a 


20.23 ”加 入 编辑 链接 的 主题 显示 页 面 


经 过 以 上 的 修改 ， 对 贴 子 进行 修改 的 准备 工作 就 算 做 完了 。 下 面 介绍 如 何 修改 贴 子 的 内 容 。 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 编 辑 贴 子 </title>\n"; 
echo "</head>\n"; 

echo "<body>\n"; 
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echo "<LINK href=\"style.css\" rel=stylesheet>\n"; 
echo "<center>\n"; 
if(!$_GET[id]) 


echo "<h2> 没 有 请 求 ID</h2>"; 
echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 
exit(); 


else 


require "20-1.php"; 
$sql="select poster,topic_id,re_id,title,content from $table posts where id='$_GET[id]"; 
$result=mysql_query($sql,$link) or die(mysql_error()); 
$rows=mysql_fetch_array($result); 
$sql2="select admin from $table members where name='$ COOKIE[user]"; 
$result2=mysql_query($sql2,$link) or die(mysql_error()); 
$rows2=mysql_fetch_array($result2); 
if(($rows[0]!=$_COOKIE[user]) or ($rows2[0]<3)) /如果 用 户 不 是 发 贴 者 或 者 不 是 管理 员 
í 

echo "<h2> 没 有 这 样 的 权限 </h2>"; 

echo "<h3> 点 <a href=\" 热 " onclick=\"history.go(-1)"> 这 里 </a> 返 回 </h3>"; 


exit(); 

} 

else 
if(!$_POST{[title]) /如 果 没 有 发 送 标题 ， 则 显示 HTML 
i 


echo "<script language=\"javascript\">\n"; 
echo "function juge(theForm)\n"; 

echo "Nn"; 

echo "\tif (theForm.title.value == \"\")\n"; 
echo "tfn"; 

echo "ttalert(\" 请 输入 主题 名 称 ! VAT 
echo "\t\ttheForm .title.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "itn"; 

echo "tif (theForm.content.value == \"\")\n"; 
echo "itin"; 

echo "talert(\" 请 输入 主题 内 容 ! \")\n"; 
echo "\t\ttheForm.content.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "itn"; 

echo "Jn"; 

echo "</script>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>\n"; 

echo "<td>"; 

echo "<center><h2> 编 辑 贴 子 </h2></center>"; 
echo "</td>\n"; 
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echo "</tr>\n"; 

echo "</table>\n"; 

$sql_t="select p_id,topic_name from $table topic where id='$rows[topic_id]"; 
$result_t=mysql_query($sql_t,$link) or die(mysql_error()); 
$rows_t=mysql_fetch_array($result_t); 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 

echo "<tr>\n"; 

echo "<td><a href=20-5.php> 论 坛 首页 </a>|<a href=20-6.php?id=".$rows _t[0]."> 主 论坛 </a>|<a 


href=20-7.php?id=".$rows[topic_id].">". $rows_t[1]."</a></td>\n"; 


echo "</tr>\n"; 

echo "</table>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 

echo "<form method=\"post\" action=\"20-12.php?id=".$_GET[id]."\" onsubmit=\"retum 


juge(this)\">\n"; 
echo "<tr>\n"; 
if($rows[re_id]==0) $re_id=$_GETIid]; // 如 果 贴 子 是 主题 
else $re_id=$rows[re_ id]; // 如 果 贴 子 不 是 主题 
echo "<input type=\"hidden\" name=\"re_id\" value=\"".$re_id."\">\n"; 
echo "<td> 输 入 标题 </td>\n"; 
echo "<td><input type=\"text\" name=\"title\" value=\"".$rows[title]."\"></td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 输 入 内 容 : </td>\n"; 
echo "<td><textarea rows=5 cols=50 name=\"content\">".$rows[content]."</textarea></td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td colspan=\"2\"><center><input type=submit value= 提 交 ><input type=reset value= 重 置 
></center></td>\n"; 
echo "</tr>\n"; 
echo "<form>"; 
echo "</table>\n"; 
echo "</center>\n"; 
echo "</body>\n"; 
echo "</html>\n"; 
} 
else // 如 果 内 容 已 经 提交 
Stitle=$_POSTItitle]; 
$content=$_POST[content]; 
$id=$_GET[id]; 
$re id=$_POST[re id); 
$sql="update $table posts set title='$title',content='$content where id='$id"; 
if(mysql_query($sql,$link)) // 如 果 更 新 语句 顺利 执行 
echo "编辑 贴 子 成 功 ， 现 在 返回 主题 显示 页 "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=20-9.php?id=".$re_id."\">"; 
} 


else 


{ 
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echo "编辑 记录 时 出 错 ， 现 在 返回 "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=20-9.php?id=".$re_id."\">"; 


把 以 上 代码 保存 为 “20-12.php”。 然 后 ， 如 果 想 对 哪 一 条 记录 进行 编辑 ， 就 可 以 单 击 图 20.23 某 
一 条 贴 子 标题 后 面 的 “编辑 ” 链接 即 可 。 当 然 前 提 是 要 有 权限 ， 如 果 没 有 相应 的 权限 ， 就 不 会 显示 出 
编辑 链接 。 但 是 有 可 能 有 恶意 的 使 用 者 通过 猜想 直接 在 地 址 栏 中 运行 。 所 以 还 要 在 编辑 页 里 进行 用 户 
身份 的 判断 。 如 果 是 不 合法 用 户 请 求 编辑 页 ， 就 会 出 现 如 图 20.24 所 示 的 提示 。 

这 里 以 管理 员 身 份 登录 ， 编 辑 如 图 20.23 所 示 的 一 条 TEST 记录 。 单 击 过 链接 后 ， 出 现 如 图 20.25 
所 示 的 执行 结果 。 
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图 20.24 非法 用 户 请 求 编 辑 页 执行 结果 图 20.25 合法 用 户 请 求 编辑 页 执行 结果 


在 这 里 可 以 对 贴 子 的 标题 及 内 容 进行 修改 ， 修 改 完成 后 直接 单 击 “ 提 交 ” 按 钮 即 可 。 这 里 把 贴 子 
内 容 修改 为 与 PHP 编程 有 关系 的 内 容 , 这 样 也 符合 PHP 编程 区 内 容 的 要 求 。 提交 操作 , 如 果 正 确 执行 ， 
程序 将 会 返回 到 主题 显示 页 。 执 行 操作 后 的 主题 显示 页 如 图 20.26 所 示 。 
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图 20.26 执行 修改 操作 后 的 主题 显示 页 
经 过 操作 ， 贴 子 内 容 及 标题 已 经 修改 成 功 。 


20.7.2 ”删除 贴 子 
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单纯 的 编辑 贴 子 ， 有 时 并 不 能 满足 要 求 ， 因 为 总 是 有 别有用心 的 人 会 在 论坛 中 放 很 多 垃圾 贴 。 有 
时 是 无 用 的 恶意 广告 贴 ， 有 时 有 色情 网 站 链接 贴 ， 有 的 则 含有 违犯 国家 法 律 、 法 规 内 容 的 贴 子 ， 对 于 
这 一 类 贴 子 必须 给 予 删除 。 这 一 小 节 介绍 如 何 删除 贴 子 。 
在 进行 删除 操作 之 前 同 编辑 贴 子 一 样 ， 也 需要 对 论坛 的 主题 显示 页 做 一 下 改动 。 在 20.7.1 小 节 加 
入 编辑 链接 的 后 面 再 跟 上 删除 链接 。 


有 具体 加 入 如 下 代码 : 


if($rows_t[admin]==3) 


echo "<a href=\"20-13.php?id=".$rows[id].\"> 删 除 </a>"; 


能 是 ， 先 判断 用 户 身份 ， 如 果 用 户 是 管理 员 则 显示 删除 链接 。 这 样 就 确保 
了 只 有 管理 员 才 能 单 击 相应 的 链接 。 修 改 后 主题 的 显示 结果 如 图 20.27 所 示 。 
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图 20.27 加 入 删除 链接 的 主题 显示 效果 


准备 工作 做 完 ， 下 面 介绍 如 何 对 贴 子 进行 删除 操作 。 这 里 还 要 分 两 种 情况 ， 一 种 是 被 删除 的 是 非 


因为 主题 通常 都 有 


主题 。 这 种 情况 很 好 办 ， 直 接 删 除 记 录 即 可 。 另 外 一 种 情况 是 删除 的 记录 是 主题 。 这 就 比较 麻烦 了 ， 
回复 ， 所 以 不 光 要 对 贴 子 记录 本 身 进行 操作 ， 还 要 对 主题 的 回复 进行 操作 。 


这 里 采用 这 样 的 处 理 机 制 ， 如 果 删 除 的 贴 子 本 身 是 主题 就 查找 它 的 所 有 回复 ， 把 第 1 条 对 主题 的 


回复 “1-1” 就 成 为 了 新 的 主题 ， 而 “1-2”、 


下 面 给 出 具体 的 代码 : 


<?php 
echo "<html>\n"; 
echo "<head>\n"; 


回复 变 为 主题 ， 原 来 对 原 主题 的 回复 都 变 成 了 对 新 主题 的 回复 。 听 起 来 好 像 很 复杂 ， 实 际 上 并 不 复杂 。 
如 有 一 个 主题 ，“1”。 


其 下 有 3 个 回复 “1-1”、“1-2”、“1-3”。 则 删除 主题 “1”， 原 来 的 


echo "<title> 删 除 贴 子 </title>\n"; 


echo "</head>\n"; 
echo "<body>\n"; 


echo "<LINK href=\"style.css\" rel=stylesheet>\n"; 


echo "<center>\n"; 
if(!$_GET][id]) 


“1-3” 则 成 了 对 新 主题 的 回复 。 
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{ 
echo "<h2> 没 有 请 求 D</h2>"; 
echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 
exit(); 
} 
else 
{ 
require "20-1.php"; 
$sql="select admin from $table members where name='$_COOKIE[user]"; 
$result=mysql_query($sql,$link) or die(mysql_error()); 
$rows=mysql_fetch_array($result); 
if($rows[0]<3) 
{ 
echo "<h2> 没 有 这 样 的 权限 </h2>"; 
echo "<h3> 点 <a href=\" 热 " onclick=\"history.go(-1)"> 这 里 </a> 返 回 </h3>"; 
exit(); 
} 
else 
{ 
$sql="select re id from $table posts where id='$_GET[id]j"; 
Sresult=mysql_query($sql,$link) or die(mysql_error()); 
$rows=mysql_fetch_array($result); 
if($rows[re_id]==0) 
{ 
$sql2="select id from $table posts where re_id='$_GETI[id] limit 1"; 
$result2=mysql_query($sql2,$link); 
$rows2=mysql_fetch_array($result2); 
$sql3="update $table posts set re_id='0' where id='$rows2[0]"; 
mysql_query($sql3, $link); 
$sql4="update $table posts set re id-'$rows2/0)' where re_id='$_GET][id]"; 
mysg! guery($sgl4,$link); 
} 
$sql="delete from $table posts where id='$_GET[id]"; 
if(mysql_query($sql,$link)) 
echo "删除 贴 子 成 功 ， 现 在 返回 论坛 首页 "; 
} 
else 
echo "删除 记录 时 出 错 ， 现 在 返回 论坛 首页 "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=20-5.php\">"; 
} 
} 
?> 


把 以 上 代码 保存 为 “20-13.php”。 单 击 图 20.27 中 的 “删除 ”链接 ， 就 相当 于 执行 了 20-13.php。 
同 理 ， 这 个 页 面 也 需要 对 用 户 的 身份 进行 验证 ， 必 须 是 管理 员 才 能 进行 这 项 操作 。 如 果 普 通用 户 或 者 
匿名 用 户 执行 这 个 页 面 , 则 会 出 现 与 图 20.24 类 似 的 提示 页 。 如 果 是 有 权限 的 管理 员 单 击 此 链接 ， 则 会 
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执行 相关 的 删除 操作 。 删 除 主题 后 的 主题 页 面 如 图 20.28 所 示 。 
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图 20.28 删除 主题 后 的 显示 
可 以 看 到 ， 原 来 的 回复 变 成 了 新 的 主题 ， 说 明 删 除 操作 成 功 。 


20.7.3 ” 防 掘 墓 功 能 
什么 是 据 墓 呢 ? 在 分 论坛 显示 页 中 ， 显 示 的 是 各 个 主题 的 基本 内 容 。 排 列 顺序 是 按照 回复 的 先后 


顺序 进行 排列 的 。 这 样 可 以 使 得 用 户 最 后 回复 的 贴 子 始终 处 于 最 上 方 ， 使 其 他 用 户 能 够 第 一 时 间 浏 览 
到 这 个 贴 子 及 回复 ， 如 图 20.29 所 示 。 


XPO RAV SEV YAA IRD EMW |a 


Ej 
分 论坛 首页 一 一 PHP 编程 
PHP, KHAAA | 


论坛 下 页 | 主 论坛 | ARMEN 


标 是 作者 | 音 看 | 回复 | 景 后 发 表 

对 TEST 的 回复 |dog |2 |0 |2006 年 10 朋 24911, 32, 23 
第 一 条 测试 信 息 | dog |3t |0 |2006 年 10 月 23920, 46. 38 
mili Er 


图 20.29 最 后 回复 的 贴 子 显示 于 最 上 方 


这 一 设 定 本 来 是 为 了 方便 用 户 能 够 及 时 发 现 最 新 的 贴 子 的 ， 但 这 样 就 会 存在 一 些 问题 ， 会 有 一 些 
无 聊 的 用 户 ， 对 很 久 以 前 的 老 贴 进行 回复 。 这 样 一 来 ， 老 主题 就 会 显示 在 分 论坛 页 面 最 醒目 的 位 置 。 
网 络 上 通常 对 这 种 恶意 回复 老 贴 子 的 行为 叫做 据 墓 。 

如 何 防止 气 墓 行为 的 发 生 呢 ? 比较 可 行 的 方法 就 是 先 设 定 一 个 最 大 允许 回复 天 数 。 如 这 一 天 数 设 
为 “5”， 表 示 如 果 主 题 留言 时 间 是 在 5 天 以 前 ， 那 么 就 不 允许 再 对 这 一 主题 进行 回复 了 。 这 样 就 可 以 
有 效 避 免 据 墓 行为 的 发 生 。 

这 要 求 在 对 贴 子 进行 回复 时 先 判 断 是 否 已 经 超过 了 最 大 允许 回复 天 数 。 如 果 超 过 了 ， 就 给 出 不 允 
许 回复 的 提示 。 这 就 要 对 20-8.php 进行 修改 ， 因 为 这 个 文件 是 发 表 主题 或 者 回复 时 要 用 到 的 页 面 。 

下 面 给 出 具体 修改 措施 。 

找到 以 下 内 容 : 


if(!$_GET[re_id]) $re_id=0; 
else $re id-$ GETIre id); 
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在 这 些 内 容 下 面 添加 如 下 内 容 : 


function next7($y,$m,$d) 

{ 
$t["01"]=$t["03"]=$t["05"]=$t["07"]=$t["08"]=$t["10"]=$t["12"]=31; 
$t["02"]=28; 
$t["04"]=$t["06"]=$t["09"]=$t["11"]=30; 
if($d+5<=$t[$m]) $d=$d+5; 
else 
{ 

$d=$d+5-$t[$m]; 

$m=$m+1; 

if(stren($m)==1) $m="0".$m; 
if($m>12) $y=$y+1; 


} 
if(strlen($d)==1) $d="0".$d; 
retum($y.$m.$d); 

} 

if($re_id!=0) 

{ 
$sql="select post time from $table posts where id-'$re id'"; 
$result=mysql_query($sql); 
$rows=mysql_fetch_array($result); 


S$last=next7(substr($rows[post_time],0,4),substr($rows[post_time],6,2),substr($rows[post_time],10,2)); 
Stemp=date(Ymd); 
if($last<$temp) 


echo "已 经 超过 5 天 了 ， 你 还 回复 什么 ?!"; 


echo "<br> 点 <a href=20-7.php?id=". $_GETI[topic_id]."> 这 里 </a> 返 回 "; 
exit(); 


} 

这 里 首先 定义 了 一 个 函数 next70， 这 一 函数 的 作用 就 是 求 某 一 天 的 5 天 后 是 哪 一 天 。 然 后 读 取 要 
回复 的 主题 的 日 期 ， 截 取出 整数 ， 再 求 其 5 天 后 是 多 少 ， 把 值 赋 给 $last 变量 。 然 后 再 与 代表 当前 日 期 
的 变量 $temp 相 比较 ， 如 果 S$last 小 于 Stemp， 则 给 出 出 错 提示 ， 并 且 中 止 所 有 操作 。 

经 过 这 样 一 处 理 ， 用 户 的 恶意 气 墓 行为 就 会 得 到 有 效 的 控制 。 

关于 贴 子 的 管理 ， 这 一 节 就 介绍 到 这 里 。20.8 节 介 绍 论坛 用 户 的 管理 。 


20.8 用 户 管 理 


一 个 用 户 在 注册 一 个 论坛 后 ， 其 各 项 信息 ， 包 括 他 的 密码 、 昵 称 ， 甚 至 性 别 、 电 子 信箱 、 图 像 、 
签名 等 内 容 都 是 可 以 改变 的 。 通 常 这 些 操作 也 都 是 由 用 户 自行 完成 。 这 一 节 就 来 讲 如 何 实现 用 户 的 
管理 。 
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20.8.1 用 户 信息 的 显示 


用 户 与 用 户 之 间 都 应 该 能 够 互相 查看 对 方 的 注册 信息 。 在 显示 主题 时 ， 在 贴 子 的 作者 一 项 上 加 上 
指向 该 用 户 信息 显示 页 的 超 链接 ， 以 实现 不 同 用 户 间 的 互相 查看 。 
这 里 就 需要 对 20-9.php 做 一 点 修改 。 找 到 如 下 的 内 容 : 
echo "作者 :".$rows[poster]; 
把 它 修改 为 : 
echo "作者 : <a href=20-14.php?id=".$rows[poster_id].">".$rows[poster]."</a>"; 
经 过 这 样 的 修改 ， 原 本 只 显示 的 用 户 名 ， 现 在 有 了 一 个 指向 ， 即 查看 用 户 信息 页 面 的 超 链接 。 
下 面 就 如 何 显示 用 户 信息 为 读者 做 介绍 。 获 取 参 数 $_GET[id]， 然 后 从 用 户 表 中 搜索 相关 记录 ， 显 
示 出 相关 信息 即 可 。 
具体 内 容 请 参看 以 下 代码 : 
<?php 
echo "<html>\n"; 
echo "<head>\n"; 
echo "<title> 显 示 用 户 信 息 </title>\n"; 
echo "</head>\n"; 
echo "<body>\n"; 
echo "<LINK href=\"style.css\" rel=stylesheet>\n"; 


echo "<center>\n"; 
if(!$_GET[id]) 
i 


echo "<h2> 没 有 请 求 ID</h2>"; 
echo "<h3> 点 <a href=# onclick=history.go(-1)> 这 里 </a> 返 回 </h3>"; 
exit(); 


else 


require "20-1.php"; 

$sql="select * from $table members where id='$_GET[id]"; 
$result=mysql_query($sql, $link) or die(mysql_error()); 
$rows=mysql_fetch_array($result); 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>\n"; 

echo "<td>"; 

echo "<center><h2> 显 示 用 户 ".$rows[name]." 信 息 </h2></center>"; 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "</table>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>\n"; 

echo "<td>"; 
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echo "<a href=\"20-5.php\"> 论 坛 首 页 </a>"; 
echo "</td>\n"; 
if($rows[name]==$_COOKIE[user]) 
{ 
echo "<td align=\"right\">"; 
echo "<a href=\"20-15.php?id=".$rows[id]. 
echo "<a href=\"20-16.php?id=".$rows[id]. 
echo "</td>\n"; 


"> 编辑 信息 </a>|"; 
> 修 改 密码 </a>"; 


} 

echo "</tr>\n"; 
echo "</table>\n"; 
echo "<table widti 
echo "<tr>\n"; 
echo "<td> 用 户 名 : </td>\n"; 

echo "<td>".$rows[name]."</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> H AREER: </td>\n"; 

echo "<td>".$rows[nickname]."</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 性 别 : </td>\n"; 

echo "<td>". $rows[sex]."</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 电 子 信箱 : </td>\n"; 

echo "<td>".$rows[email]."</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 用 户 图 像 </td>\n"; 

echo "<td>"; 

if($rows[photo]) echo "<img src=images/". $rows[photo].">"; 
else echo "该 用 户 没有 设置 图 像 "; 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 签 名 : </td>\n"; 

echo "<td>"; 

if($rows[q_name]) echo $rows[q_name]; 
else echo "该 用 户 没有 设置 签名 档 "; 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 发 贴 数 量 : </td>\n"; 

echo "<td>".$rows[post_num]."</td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 注 册 日 期 : </td>\n"; 

echo "<td>". $rows[reg_date]."</td>\n"; 


=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
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echo "</tr>\n"; 
echo "</table>\n"; 
echo "</center>\n"; 
echo "</body>\n"; 
echo “</html>\n"; 

} 

?> 


把 上 面 这 段 代码 保存 为 “20-14.php”。 在 PHP 环境 下 执行 该 文件 ， 如 果 是 匿名 用 户 浏览 某 用 户 的 
信息 , 其 执行 结果 会 如 图 20.30 所 示 。 从 图 20.30 的 执行 结果 可 以 看 到 页 面具 显示 出 了 用 户 的 基本 信息 。 
如 果 某 用 户 查 看 自己 的 信息 ， 执 行 结果 将 会 有 如 图 20.31 所 示 。 


EE 
E) 
显示 用 户 dog 信 息 
论坛 首页 
用 户 名 ， dog ly 
APER dog YRO RU FEO HRU TAD ENW L 
TESI: boy z 
电子 信箱 ， dog@2.com 
用 户 图 像 议 用 户 梁 有 设置 图 你 
签名 ， 该 用 户 没有 设置 签名 档 
RERE: z 
注册 日 期， 2005 年 0 月 23 昌 Bl 


TEF 
图 20.30 匿名 用 户 浏览 其 他 用 户 的 信息 图 20.31 注册 用 户 查看 自己 的 信息 
可 以 看 到 ， 注 册 用 户 查 看 自己 的 信息 ， 会 显示 出 指向 编辑 信息 与 修改 密码 页 面 的 链接 。 用 户 可 以 
通过 这 些 连 接 轻 松 实现 对 自己 的 信息 及 密码 的 修改 。 
20.8.2 小 节 介绍 如 何 使 用 户 能 够 修改 自己 的 注册 信息 。 


20.8.2 ”普通 信息 的 修改 


这 一 小 节 介绍 如 何 使 用 户 能 够 修改 自己 的 普通 信息 。 当 然 用 户 也 不 能 随意 修改 自己 的 所 有 信息 ， 
如 用 户 名 、 发 贴 数 、 注 册 日 期 、 管 理 员 等 级 就 不 能 让 用 户 随 意 修 改 。 除 此 之 外 能 够 改动 的 就 具有 了 昵 
称 、 性 别 、 电 子 信箱 、 论 坛 图 像 、 发 贴 个 性 签名 这 些 内 容 了 。 下 面 介绍 如 何 实现 对 用 户 这 些 信息 的 
修改 。 

具体 内 容 请 参看 如 下 代码 : 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 修 改 用 户 信息 </title>\n"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "<LINK href=\"style.css\" rel=stylesheet>\n"; 
echo "<center>\n"; 
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#($ GETId)) 


{ 


echo "<h2> 没 有 请 求 D</h2>"; 
echo "<h3> 点 <a href=# onclick=history.go(-1)> 这 里 </a> 返 回 </h3>"; 
exit(); 


} 


else 


{ 


require "20-1 .php"; 

$sql="select * from $table members where id='$_GET[id]"; 
$result=mysql_query($sql, $link) or die(mysql_error()); 
$rows=mysql_fetch_array($result); 
if($rows[name]!=$_COOKIE[user]) 


else 


echo "<h2> 请 求 ID 与 用 户 身份 不 符 ! </h2>"; 
echo "<h3> 点 <a href=# onclick=history.go(-1)> 这 里 </a> 返 回 </h3>"; 
exit(); 


echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>\n"; 

echo "<td>"; 

echo "<center><h2> 修 改 用 户 ".$rows[name]." 信 息 </h2></center>"; 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "</table>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>\n"; 

echo "<td>"; 

echo "<a href=\"20-5.php\"> 论 坛 首页 </a>"; 

echo "</td>\n"; 

echo "<td align=\"right\">"; 
echo "<a href=\"20-14.php?| 
echo "<a href=\"20-16.php?id=' 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "</table>\n"; 
if(!I$POST[$nickname]) 

{ 


".$rows[id].\"> 显 示 信息 </a>|"; 
.$rows[idj."\"> 修 改 密码 </a>"; 


echo "<script language=\"javascript\">\n"; 
echo "function juge(theForm)\n"; 

echo "Nn"; 

echo "\tif (theForm.nickname.value == \"\")\n"; 
echo "tfn"; 

echo "ttalert(\" 请 输入 昵称 ! Van" 

echo "t\ttheForm.title.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo “tAn"; 


juge(this)\">\n"; 
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echo "An"; 

echo "function s_photo(the)\n"; 
echo "Nn"; 

echo "\tdocument.img.src='images/'+the.photo.value+'.bmp';\n"; 
echo "Jn"; 

echo "</script>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\" 
echo “<form method=\"post\" action=\"20-15.php?i 


1\">\n"; 


echo "<tr>\n"; 

echo "<td> H AREER: </td>\n"; 

echo "<td>"; 

echo "<input type=\"text\" name=\"nickname\" value=\"".$rows[nickname]."\">"; 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 性 别 : </td>\n"; 

echo "<td>"; 

echo "<input type=\"radio\" name=\"sex\" value=\"boy\" "; 
if($rows[sex]=="boy") echo " checked "; 

echo ">B"; 

echo "<input type=\"radio\" name=\"sex\" value=\"gir\" "; 
if($rows[sex]=="girl") echo " checked "; 

echo "> 女 "; 

echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 电 子 信箱 : </td>\n"; 

echo "<td>"; 

echo "<input type=\"text\" name \"email\" value=\"". $rows[email]."\">"; 
echo "</td>\n"; 


echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 用 户 图 像 </td>\n"; 
echo "<td>"; 


echo "<select name=\"photo\" size=\"1\" onchange=\"s_photo(this.form)\">\n"; 
for($i=1;$i<21;$i++) 


{ 
echo "<option value=".$i.">".$i."</option>\n";; 
F 
echo "</select>"; 
if(!$rows[photo]) 
echo "用 户 没有 设置 图 像 <br>"; 
echo "<img src=\"images/1.bmp\" name=\"img\">"; 
} 
else 
{ 


echo "<img src=\"images/".$rows[photo]."\" name=\"img\">"; 
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} 

echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 答 名 : </td>\n"; 

echo "<td>"; 

echo "<input type=\"text\" name \"q_name\" value=\"".$rows[q_name]."\">"; 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td colspan=\"2\"><center>"; 

echo "<input type=submit value=\" 提 交 \">"; 
echo "</center></td>\n"; 

echo "</tr>\n"; 

echo "</form>"; 

echo "</table>\n"; 

echo "</center>\n"; 

echo "</body>\n"; 

echo "</html>\n"; 


else 


$nickname=$_POST[nickname]; 

$sex=$_POST[sex]; 

$email=$_POST[email]; 

$photo=$_POST[photo]; 

$q_name=$_POST[q_name]; 

$id=$_GET[id]; 

$sql="update $table_ members set 
nickname='$nickname'sex='$sex',email='$email,photo='$photo',q_name='$q_name' where id='$id"; 

if(mysql_query($sql,$link)) 


echo "修改 注册 信息 成 功 ， 现 在 返回 查看 信息 页 "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=20-14.php?id=".$id."\">"; 


} 
else 
echo "修改 注册 信息 失败 ， 现 在 返回 修改 用 户 记 录 页 "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=20-15.php?id=".$id."\">"; 
} 
} 
} 
} 
?> 


把 以 上 代码 保存 为 “20-15.php”。 单 击 图 20.31 中 的 “编辑 信息 ” 超 链 接 ， 就 可 以 打开 该 文件 。 
打开 后 的 执行 结果 如 图 20.32 所 示 。 

这 里 只 对 需要 改动 的 内 容 进行 更 改 ， 然 后 单 击 “ 提 交 ” 按 钮 ， 就 可 以 把 修改 信息 提交 到 后 台 进行 
处 理 。 如 果 操 作 正 确 执行 ， 新 的 用 户 将 代替 以 前 的 信息 。 用 户 信息 修改 成 功 。 
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图 20.32 ”修改 用 户 信息 执行 结果 


20.8.3 用 户 密码 的 修改 


它 是 用 户 登 录 系 统 的 最 重要 的 “钥匙 ”。 所 以 要 把 对 密码 的 修 


密码 修改 的 机 理 是 这 样 ， 先 让 用 户 分 别 输入 旧 密 码 及 新 的 密码 。 然 后 在 后 台 进 行 判 断 ， 如 果 用 户 
所 输入 的 旧 密 码 与 库 里 保存 的 一 致 ， 则 执行 把 旧 密 码 更 改 为 新 密码 的 SQL 语句 。 反 之 ， 如 果 用 户 输入 


不 一 致 ， 则 给 出 出 错 提示 。 
下 面 给 出 具体 代码 : 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 修 改 用 户 密码 </title>\n"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "<LINK href=\"style.css\" rel=stylesheet>\n"; 
echo "<center>\n"; 

if(!$_GET][id]) 


echo "<h2> 没 有 请 求 ID</h2>"; 
echo "<h3> 点 <a href=# onclick=history.go(-1)> 这 里 </a> 返 回 </h3>"; 
exit(); 


else 

{ 
require "20-1.php"; 
$sql="select * from $table members where id='$_GET[id]"; 
$result=mysql_query($sql,$link) or die(mysql_error()); 
$rows=mysql_fetch_array($result); 
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if($rows[name]!=$_COOKIE[user]) 


{ 


else 


echo "<h2> 请 求 ID 与 用 户 身 份 不 符 ! </h2>"; 
echo "<h3> 点 <a href=# onclick=history.go(-1)> 这 里 </a> 返 回 </h3>"; 
exit(); 


echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>\n"; 
echo "<td>"; 
echo "<center><h2> 修 改 用 户 ".$rows[name]." 的 密码 </h2></center>"; 
echo "</td>\n"; 
echo "</tr>\n"; 
echo "</table>\n"; 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>\n"; 
echo "<td>"; 
echo "<a href=\"20-5.php\"> 论 坛 首页 </a>"; 
echo "</td>\n"; 
echo "<td align=\"right\">"; 
echo "<a href=\"20-14.php?id=".$rows[id]."w> 显 示 信息 </a>|”; 
echo "<a href=\"20-15.php?id=".$rows[id]."\"> 修 改 信息 </a>"; 
echo "</td>\n"; 
echo "</tr>\n"; 
echo "</table>\n"; 
if(!$_POST[password]) 
{ 
echo "<script language=\"javascript\">\n"; 
echo "function juge(theForm)\n"; 
echo "An"; 
echo "\tif (theForm.password.value == \"\")\n"; 
echo "itin"; 
echo ttalert(\" 请 输入 旧 密 码 ! \")An"; 
echo "\t\ttheForm.password.focus();\n"; 
echo "\t\treturn (false);\n"; 
echo "tjn"; 
echo "tif (theForm.newpassword.value == \"\")\n"; 
echo "itin"; 
echo "t\talert(\" 请 输入 新 密码 ! \");\n"; 
echo "\t\ttheForm.newpassword.focus();\n"; 
echo "\t\treturn (false);\n"; 
echo "An"; 
echo "tif (theForm.newpassword.value.length <8)\n"; 
echo "tin"; 
echo "ttalert(\" 密 码 要 在 8 位 以 上 ! \");\n"; 
echo "t\ttheForm.newpassword.focus();\n"; 
echo "\t\treturn (false);\n"; 
echo "tjn"; 


echo "tif (theForm.newpassword.value != theForm.repassword.value)\n"; 


juge(this)\">\n"; 


else 
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echo "tin"; 

echo "\t\talert(\" 重 复 输入 的 密码 不 一 致 !\");\n"; 

echo "\t\ttheForm.repassword.focus()\n"; 

echo "\t\treturn (false);\n"; 

echo "tn"; 

echo "}\n"; 

echo "</script>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacinmt 
echo "<form method=\"post\" action=\"20-16.php?ii 


echo "<tr>\n"; 

echo "<td> 输 入 旧 密码 : </td>\n"; 

echo "<td>"; 

echo "<input type=\"password\" name=\"password\">"; 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 输 入 新 密码 : </td>\n"; 

echo "<td>"; 

echo "<input type=\"password\" name=\"newpassword\">"; 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 再 输入 一 次 : </td>\n"; 

echo "<td>"; 

echo "<input type=\"password\" name=\"repassword\">"; 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td colspan=\"2\"><center>"; 

echo "<input type=submit value=\" 提 交 \">"; 

echo "</center></td>\n"; 

echo "</tr>\n"; 

echo "</form>"; 

echo "</table>\n"; 

echo "</center>\n"; 

echo "</body>\n"; 

echo "</html>\n"; 


$password=md5($_POST[password]); 
$newpassword=md5($_POST[newpassword]); 
$id=$_GETIid]; 

$sql="select id from Stable members where 


password-'$password"; 


$result=mysql_query($sql,$link); 
$nums=mysql_num_rows($result); 
if($nums<1) 


{ 


ww 
$_GET[idlw 


name='$_COOKIE[user] 
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onsubmit=\"return 
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echo "输入 的 用 户 密码 错误 ! <p>"; 


echo "请 重新 输入 !"; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=20-16.php?id=".$id."\">"; 
} 
else 
{ 
$sql="update $table members set password='$newpassword where id='$id"; 
if(mysql_query($sql,$link)) 
echo "修改 用 户 密码 成 功 ， 现 在 返回 查看 信息 页 "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=20-14.php?id=".$id."\">"; 
$ 
else 
echo "修改 用 户 密码 失败 ， 现 在 返回 修改 用 户 记录 页 "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=20-15.php?id=".$id."\">"; 
} 
F 
} 
} 
} 
?> 


将 上 面 代码 保存 为 “20-16.php”。 然 后 单 击 图 20.32 中 的 “修改 密码 ” 超 链 接 ， 就 可 以 执行 该 文 
件 。 其 执行 结果 如 图 20.33 所 示 。 


YEU RED 5y gW TAD MN Ee 


pm 
是 
习 
修改 用 户 dog 的 这 到 
论坛 首页 于 示 信 息 | 修改 信息 
s 


输入 日 密码 ， 
RARER.: 
再 输入 一 次 ， 


[E COO Lr 


20.33 ”用 户 修改 密码 执行 结果 


依次 输入 用 户 的 旧 密 码 、 新 密码 、 重 复 新 密码 ， 然 后 单 击 “ 提 交 ” 按 钮 ， 就 可 以 把 输入 内 容 提交 
到 后 台 进 行 处 理 。 

如 果 用 户 输入 正确 ， 并 且 执 行 了 相关 操作 ， 则 用 户 的 旧 密 码 就 会 被 新 密码 蔡 代 ， 以 完成 修改 密码 
的 操作 。 


20.8.4 MARERE 


通常 情况 下 ， 还 应 该 设计 一 个 用 户 退出 登录 的 页 面 ， 以 方便 用 户 随时 退出 系统 。 为 了 使 主 程序 能 
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够 访问 该 页 面 ， 还 应 该 对 论坛 首页 文件 进行 修改 ， 以 加 入 该 页 的 链接 。 


在 20-5.php 中 找到 以 下 内 容 : 
echo "<td>"; 
if(!$_COOKIE[user]) // 如 果 没 有 用 户 登录 ， 则 显示 登录 连接 
{ 
echo "<a href=\"20-4.php\"> 用 户 登 录 </a>"; 
$ 
else /如果 用 户 已 经 登录 ， 则 显示 登录 用 户 名 
{ 
require "20-1.php"; 
$sql="select id from $table members where name='$_COOKIE[user]"; 
$result=mysql_query($sql,S$link); 
$rows=mysql_fetch_array($result); 
echo "登录 用 户 : <a href=20-14.php?id=".$rows[0].">".$_COOKIE[user]."</a>"; 
echo "</td>\n"; 
将 其 修改 为 : 
echo "<td>"; 
if(!$_COOKIE[user]) // 如 果 没有 用 户 登录 ， 则 显示 登录 连接 
f 
echo "<a href=\"20-4.php\"> 用 户 登 录 </a>"; 
} 
else // 如 果 用 户 已 经 登录 ， 则 显示 登录 用 户 名 
í 
require "20-1 .php"; 
$sql="select id from $table members where name='$_COOKIE[user]"; 
$result=mysql_query ($sql, $link); 
$rows=mysql_fetch_array($result); 
echo "登录 用 户 ，<a href=20-14.php?id=".$rows[0].">".$_COOKIE[user]."</a>|"; 
echo "<a href=20-17.php> 退 出 登录 </a>"; 
} 
echo "</td>\n"; 


经 过 这 样 的 修改 就 为 主页 面 加 入 了 用 户 退 出 的 链接 。 
其 实用 户 的 退出 操作 极其 简单 ， 清 空 用 户 注册 的 Cookie 记录 ， 然 后 再 跳 转 到 指定 页 即 可 。 下 面 给 
出 具体 实现 代码 : 


<?php 

setcookie("user",""); 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 登 录用 户 安全 退出 </title>\n"; 

echo "<meta http-equiv=\"refresh\" content=\"2; url=20-5.php\">"; 
echo "</head>\n"; 

echo "<body>\n"; 

echo "<LINK href=\"style.css\" rel=stylesheet>\n"; 
echo "<center>\n"; 

echo "<h2> 登 录用 户 已 经 退出 </h2>\n"; 
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echo "<h3> 两 秒 后 返回 论坛 首页 </h3>\n"; 

echo "</center>\n"; 

echo "</body>\n"; 

echo "</html>\n"; 

?> 

把 上 面 代码 保存 为 “20-17.php”。 当 登录 用 户 单 击 “ 退 出 登录 ” 链接 后 ， 用 户 就 能 安全 地 从 系统 
退出 。 

至 此 ， 用 户 管理 工作 基本 上 就 算是 完整 了 ， 不 但 能 够 显示 用 户 信息 ， 而 且 能 够 更 改 用 户 信息 ， 可 
以 满足 一 般 的 要 求 了 。 


209 进一步 完善 


现在 ， 论 坛 程序 已 经 基本 上 能 够 满足 大 部 分 需求 了 ， 但 与 通常 的 论坛 相 比 还 存在 很 多 不 足 。 大 致 
有 以 下 儿 个 方面 : 

口 不 具有 文件 上 传 功能 。 通 常 的 论坛 都 会 在 用 户 发 表 新 主题 或 者 回复 时 有 一 个 文件 上 传 界面 允 
许 用 户 上 传 指定 类 型 及 限制 大 小 的 文件 。 这 个 问题 也 很 容易 实现 ， 关 于 如 何 上 传 文件 请 参看 
本 书 第 8 章 的 内 容 ， 这 里 只 给 出 思路 。 当 用 户 上 传 文件 后 ， 在 提交 用 户 发 表 主题 或 回复 的 内 
容 最 后 加 上 指向 文件 下 载 页 面 的 链接 。 而 专门 的 文件 下 载 页 面 则 指向 该 上 传 的 文件 。 这 样 就 
可 以 显示 指定 文件 ， 用 户 也 可 以 下 载 该 文件 了 。 

口 用 户 与 用 户 之 间 不 能 传送 信息 。 通 常 的 论坛 还 会 有 一 个 信息 系统 ， 即 不 同 的 用 户 之 间 可 以 互 
相 发 送信 息 ， 只 有 接收 人 才能 够 查看 。 当 用 户 登 录 论 坛 时 ， 如 果 有 未 阅读 的 新 信息 ， 则 系统 
会 提示 用 户 进行 阅读 。 这 也 是 一 个 相当 有 用 的 功能 ， 实 现 起 来 也 并 不 复杂 。 只 需要 在 原 有 的 
表 结 构 上 再 加 一 个 信息 表 (MSN) 。 表 一 共有 这 样 几 个 字段 : ID、 发 件 人 、 收 件 人 、 内 容 、 
是 否 显示 、 是 否 阅读 等 。 然 后 为 收 、 发 信息 建立 专门 的 页 面 。 任 何 用 户 都 只 能 查看 收 件 人 为 
自己 名 字 的 信息 。 也 可 以 给 其 他 人 发 送信 息 。 信 息 的 阅读 初始 状态 为 False， 当 用 户 登 录 论坛 ， 
用 检查 是 否 有 收 件 人 为 用 户 名 ， 阅 读 状态 为 False 的 信息 ， 如 果 有 就 提醒 用 户 进行 阅读 。 信 息 
在 用 户 阅读 过 后 ， 阅 读 状态 就 为 True。 用 户 也 可 以 选择 删除 自己 收 件 箱 中 的 信息 ， 而 实际 上 
的 删除 操作 只 是 把 显示 状态 改 为 False。 这 样 就 不 再 显示 该 信息 。 这 里 只 给 出 了 实现 机 制 ， 有 
兴趣 的 读者 可 以 自行 研究 以 实现 该 功能 。 

D 没有 为 用 户 定义 级 别 ， 普 通用 户 无 法 体会 到 升级 的 乐趣 。 通 常 的 论坛 都 会 为 用 户 根据 发 贴 数 
量 ,或 者 积分 设 定 级 别 ,如 0~50 为 初级 用 户 ,50~100 为 中 级 用 户 ,100~200 为 高 级 用 户 ,200~500 
为 超级 用 户 ，500~1000 为 帝王 等 。 这 样 可 以 鼓励 用 户 不 断 发 贴 以 提高 自己 的 级 别 。 要 实现 这 
样 的 功能 有 多 种 方法 ， 一 种 就 是 把 相应 的 级 别 直 接 写 入 用 户 表 中 的 某 个 字段 ， 如 LEVEL。 在 
用 户 发 过 贴 时 判断 其 发 贴 数 属于 哪 一 个 级 别 ， 再 把 相应 级 别 写 入 该 字段 。 这 样 随 着 发 贴 数 的 
增加 ， 用 户 的 级 别 就 会 不 断 增 加 。 但 这 样 存在 一 个 次 端 ， 就 是 当 用 户 级 别 固 定 后 ， 想 再 更 改 
就 相当 困难 了 ， 如 以 前 的 级 别 这 样 定义 : 初级 、 中 级 、 高 级 、 超 级 等 ， 现 在 想 把 用 户 级 别 表 
示 方 式 改 为 : 学 前 班 、 小 学 生 、 初 中 生 、 高 中 生 、 学 士 、 硕 士 、 博 士 等 。 如 果 一 条 一 条 改 就 
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会 相当 困难 ， 而 且 在 实际 中 根本 是 不 可 能 的 ， 所 以 可 以 采用 这 样 的 方法 ， 不 设 定 用 户 的 级 别 
字段 。 当 在 需要 显示 用 户 级 别 时 ， 读 取 用 户 的 发 贴 数 与 特定 配置 文件 中 的 分 数 段 表示 值 进行 
比较 。 用 户 属于 哪个 范围 ， 就 显示 相应 的 级 别 ， 如 现在 有 配置 文件 ， 定 义 0~50 为 初级 用 户 ， 
50~100 为 中 级 用 户 ，100~200 为 高 级 用 户 ，200~500 为 超级 用 户 ，500~1000 为 帝王 。 显 示 时 
把 用 户 发 贴 数 与 这 些 配置 进行 比较 ， 属 于 哪个 范围 ， 就 显示 相应 的 级 别 。 而 想 更 改 级 别 表示 
方法 时 只 需要 更 改 配 置 文件 即 可 。 这 样 可 以 保证 级 别 表示 方法 的 可 移植 性 。 限 于 篇 幅 也 不 再 
给 出 具体 代码 ， 有 兴趣 的 读者 ， 可 以 去 尝试 进行 。 

O 只 有 一 个 超级 管理 员 ， 各 个 分 论坛 没有 相应 的 版 主 。 如 果 要 求 版 主 ， 就 要 给 每 个 论坛 分 类 。 
不 管 是 主 分 类 还 是 二 级 分 类 都 增加 一 个 字段 用 于 存放 版 主 的 ID, 然 后 再 把 相应 用 户 的 ADMIN 
值 改 为 1， 以 区 别 于 普通 用 户 ， 然 后 再 给 这 些 版 主 赋予 相应 权限 即 可 。 

口 ”对 用 户 的 输入 没有 过 滤 功 能 。 用 户 的 恶意 输入 会 对 论坛 造成 破坏 ， 所 以 应 该 屏蔽 用 户 的 输入 ， 
以 处 理 掉 HTML 标记 。 只 需要 使 用 htmlspecialchars0) 函 数 对 用 户 输入 进行 处 理 即 可 ， 这 里 也 
不 再 次 述 。 

O 其 他 更 为 高 级 的 功能 。 一 个 完整 的 论坛 还 应 有 更 多 的 功能 ， 如 在 线 用 户 列 表 、 用 户 生 日 友情 
提示 、 版 主 可 以 奖励 用 户 积分 、 置 顶 贴 、 精 华 贴 等 。 可 以 这 样 说 ， 要 想 讲 清楚 论坛 的 所 有 功 
能 都 需要 一 本 书 。 由 于 本 书 的 篇 幅 所 限 ， 只 能 讲 些 最 基本 的 功能 ， 更 多 的 功能 都 有 待 读者 在 
以 后 的 学 习 中 进一步 研究 完成 。 


20.10 本 章 小 结 


这 一 章 向 读者 介绍 了 如 何 用 所 学 的 PHP 知识 来 实现 一 个 简单 的 论坛 。 本 章 把 一 个 论坛 分 解 为 表 的 
设计 、 所 需 库 表 的 创建 、 用 户 的 注册 与 登录 、 论 坛 的 显示 、 主 题 的 发 表 与 回复 、 论 坛 分 类 的 管理 、 贴 
子 的 管理 、 用 户 的 管理 儿 大 项 ， 分 别 进行 了 说 明 。 通 过 本 曹 的 学 习 ， 用 户 不 仅 进一步 深化 了 PHP 对 
MySQL 数据 库 的 操作 。 而 且 对 于 如 何 通过 PHP 代码 、 算 法 来 解决 实际 问题 都 会 有 一 个 深刻 的 认识 。 
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这 一 章 ，, 结合 前 面 所 学 的 内 容 来 制作 一 个 网 上 商城 全 站 系统 。 相信 读者 在 上 网 冲浪 
时 都 见 过 各 式 各 样 的 网 上 商城 ,注册 用 户 可 以 在 上 面 购买 自己 喜欢 的 商品 ， 并 向 读者 介 
绍 如 何 使 用 PHP 再 加 上 MySQL 数据 库 来 实现 一 个 网 上 商城 全 站 系统 。 通 过 本 章 的 学 
习 ， 相 信 读 者 会 对 PHP 及 MySQL 的 知识 有 一 个 全 新 的 认识 。 
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21.1 系统 分 析 


在 制作 系统 之 前 ， 首 先 需要 分 析 系 统 所 要 实现 的 功能 ， 以 明确 制作 目的 。 只 有 目的 明确 才能 有 的 
放 矢 ， 使 接 下 来 的 的 工作 事半功倍 ， 提 高 工作 效率 。 作 为 一 个 网 上 商城 ， 面 对 的 是 用 户 ， 所 以 必 不 可 
少 的 就 要 有 一 个 用 户 注 册 与 登录 系统 ， 这 是 构建 用 户 系统 的 前 提 。 用 户 有 系统 管理 员 与 普通 用 户 之 分 。 

1. 系统 管理 员 

管理 员 在 登录 系统 后 ， 可 以 在 后 台 对 图 书记 录 表 进行 增加 和 删除 操作 。 他 也 可 以 在 后 台 修 改 图 书 
的 类 别 ， 查 看 、 操 作 回 复 用 户 的 购书 订单 。 

2. 普通 用 户 

普通 用 户 登录 后 ， 则 能 进行 浏览 图 书 、 查 找 图 书 等 操作 。 浏 览 图 书 可 以 给 予 用 户 一 定 的 自由 ， 如 
按 种 类 浏览 或 者 按 添 加 时 间 浏 览 等 。 搜 索 图 书 也 有 一 定 的 自由 性 ， 用 户 可 以 把 图 书 名 称 、 图 书 作 者 、 
出 版 图 书 的 出 版 社 、 图 书 所 属 的 类 别 或 者 价格 等 多 种 条 件 作 为 搜索 条 件 对 图 书 进 行 搜索 。 

普通 用 户 也 可 以 查看 图 书 详细 情况 ， 并 把 图 书 加 入 购物 车 。 添 加 到 购物 车 后 ， 用 户 就 可 以 随时 查 
看 购物 车 内 容 ， 更 改 购物 车 。 例 如 ， 可 以 更 改 购物 车 中 某 一 类 商品 的 数量 ， 或 删除 某 一 类 商品 。 在 确 
定 了 所 购 图 书后 ， 在 前 台 提交 购物 车 ， 给 商城 下 订单 。 


21.2 设计 数据 库 表 结 构 


数据 表 设 计 的 成 功 与 否 直 接 影 响 到 程序 的 执行 效率 。 这 一 节 完成 数据 库 表 结构 的 设计 。 在 整个 系 
统 中 ， 要 实现 系统 分 析 所 要 求 的 功能 ， 共 需要 建立 5 个 表 ， 即 用 户 表 、 图 书 类 型 表 、 图 书记 录 表 、 订 
单 表 和 销售 记录 表 等 。 


21.2.1 用 户 表 的 设计 


用 户 表 主 要 存放 注册 用 户 的 信息 。 该 表 主 要 包括 索引 ID、 用户 名 、 用 户 密码 、 用 户 图 像 、 用 户 的 
地 址 、 电 子 信箱 、QQ 号 码 、MSN 地 址 、 注 册 时 间 、 购 物 数量 等 基本 信息 ， 其 中 还 应 有 一 字段 用 以 判 
断 用 户 身份 ， 如 果 该 字段 值 为 “0”， 则 为 普通 用 户 ;如 果 为 为 “1”， 则 表示 用 户 为 管理 员 。 该 表 具 
体 字段 如 表 21.1 所 示 。 


表 21.1 用 户 表 user 


w 


id 索引 ID 主键 、 自 动 增 1) 
varchar(12) 用 户 名 
| aa | 百 | 
| aa | 五 | 
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续 表 

字 段 名 数据 类 型 是 否 允 许 为 空 说 AA 

address varchar(80) 否 用 户 的 地 址 

email varchar(80) 否 电子 信箱 

qq varchar(15) E QQ 号 码 

msn varchar(80) E MSN 地 址 

reg date varchar(20) F 注册 时 间 

post num int(5) 否 发 贴 数量 

admin int(1) 否 用 户 身份 判断 


2122 ”图书 类 型 表 的 设计 


图 书 类 型 表 存 放 图 书 的 类 别 ， 图 书 的 类 别 有 二 级 分 类 ， 如 主 类 别 为 电脑 类 用 书 ， 二 级 类 别 可 以 分 
别 为 硬件 类 、 软 件 类 、 网 络 类 、 电 子 娱乐 类 等 。 要 实现 这 样 的 分 类 ， 必 须 有 图 书 类 别 表 来 存放 。 该 表 
应 该 包含 的 基本 信息 有 : 索引 ID、 主 类 别 ID、 类 别名 称 、 类 别 介绍 、 类 别 数量 等 。 该 表 具 体 字段 如 
表 21.2 所 示 。 

表 21.2 类 型 表 type 
int(5) 索引 ID (主键 、 自 动 增 1) 
int(5) F 子 类 别 所 属 主 类 别 ID 
e 类 别名 称 
type description Sj 


int(5) 本 类 别 的 贴 子 数 ， 当 发 本 类 贴 时， 该 值 增加 1 


21.2.3 图 书记 录 表 的 设计 


图 书记 录 表 存 入 图 书 的 所 有 主要 信息 ， 大 致 有 以 下 内 容 : 索引 ID、 书 名 、 作 者 、 出 版 社 、 所 属 子 
分 类 、 价 格 、 内 容 简介 、 封 面 扫描 图 、 已 售 出 量 和 存货 量 等 。 该 表 具 体 字 段 如 表 21.3 所 示 。 


表 21.3 图 书记 录 表 book 


字 段 名 数据 类 型 是 否 人 允许 为 空 说 AA 
id int(5) 索引 ID (主键 、 自 动 增 1) 
book name varchar(40) 图 书 的 名 称 
book author varchar(20) 图 书 的 作者 
book pub varchar(40) 图 书 的 出 版 社 
book type int(5) 图 书记 属 类 别 
book cost varchar(6) 图 书 售 价 
book description varchar(200) 图 书 描述 
book photo varchar(80) 图 书 封面 扫描 图 
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续 表 


字 段 名 


book sale num 


book num 


是 否 允 许 为 空 
否 
否 


21.2.4 ”订单 记录 表 的 设计 


订单 是 这 样 一 个 概念 ， 用 户 在 选择 了 相应 商品 并 提交 后 ， 提 交 的 这 些 记录 将 以 订单 的 形式 保存 在 
订单 记录 表 中 。 只 有 当 管 理 者 回复 了 这 些 订 单 ， 并 且 完 成 了 交易 ， 相 应 的 订单 才 会 变 成 真正 的 销售 记 
录 。 一 个 订单 表 应 该 包括 如 下 内 容 : 索引 ID、 提交 者 ID、 提 交 者 用 户 名 、 所 购 图 书信 息 〈 这 其 中 包括 
所 购 图 书 ID、 数 量 )、 订 单 总 额 (为 此 次 所 有 购书 的 总 额 )、 回 复 状 态 (用 户 提交 后 , 初始 状态 为 False， 
当 管 理 员 回复 该 订单 后 ， 状 态 变 为 True) 、 提 交 时 间 “〈 用 户 提交 订单 的 时 间 ) 等 。 该 表 具 体 字 段 如 
表 21.4 所 示 。 


表 21.4 订单 记录 表 order 


字 段 名 数 据 类 型 说 明 

id int(5) | 否 | 索引 ID (主键 、 自 动 增 1) 
order user id int(5) 提交 者 名 称 

order user name varchar(20) 提交 者 ID 

order book id int(5) 所 购 图 书 ID 

order book num int(5) 购书 数量 

order_content varchar(80) 订单 内 容 

order cost varchar(10) | 否 | 订购 价格 

order state enum('true','false') 订单 状态 

order date varchar(40) 订购 时 间 


21.2.5 ”销售 记录 表 的 设计 


销售 记录 表 是 直接 由 订单 表 变 化 而 来 的 ， 用 户 提交 的 订单 经 管理 员 回 复 后 就 变 成 实 实在 在 的 销 
售 记录 ， 所 以 ， 该 表 内 容 与 订单 表 基 本 类 似 ， 只 不 过 多 一 个 回复 时 间 字 段 。 该 表 具 体 字 段 如 表 21.5 
所 示 。 


表 21.5 MAR user 


字 段 名 数 据 类 型 
ja | no 


是 否 允 许 为 空 说 AA 


索引 ID〈 主 键 、 自 动 增 1) 
sale order id int(5) 对 应 订单 ID 


销售 时 间 〈 即 管理 员 


复 时 间 》 


sale date varchar(40) 


至 此 ， 该 系统 所 需要 的 5 个 表 全 部 设计 完毕 。 从 21.3 节 开 始 将 通过 具体 的 代码 来 实现 网 上 商城 全 
站 系统 的 所 有 功能 。 
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21.3 准备 工作 
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在 开始 实现 网 上 商城 全 站 系统 的 所 有 功能 之 前 ， 要 做 一 些 必 要 的 准备 工作 。 其 中 一 项 就 是 建立 配 
置 文件 ， 以 便 以 在 后 面 的 程序 中 调用 。 另 一 个 是 要 创建 系统 运行 所 需要 的 各 种 表 ， 即 进行 系统 的 安装 。 


这 一 节 将 具体 实现 这 些 工 作 。 


21.3.1 配置 文件 的 创建 


和 前 面 儿 章 所 讲 到 与 数据 库 相关 的 程序 一 样 ， 程 序 所 访问 的 主机 名 、 连 接 主机 的 用 户 名 、 用 户 密 
码 及 数据 库 名 通常 都 是 固定 不 变 的 。 各 种 表 名 ， 在 创建 后 也 是 不 会 改变 的 ， 所 以 应 该 把 这 些 重 要 的 变 
量 单独 拿 出 来 做 成 配置 文件 ， 以 便 其 他 程序 文件 来 调用 。 在 配置 文件 中 存放 着 程序 运行 所 需要 的 数据 


库 的 主机 名 、 连 接 主机 的 用 户 名 、 密 码 、 数 据 库 名 和 表 名 等 信息 。 
下 面 就 来 建立 配置 文件 。 具 体内 容 参 看 以 下 代码 : 


<? 

$db host-"localhost"; /主机 名 
$db_user="root"; IAPR 
$db_pass=""; /密码 
$db_name="test"; /| 数据 库 名 
$table_user="user'; IAPR 
$table_type="type"; /图 书 分 类 表 
S$table_book="book"; /图 书记 录 表 
$table_order="order"; // 订 单 表 
$table_sale="sale"; UA 
$link=mysql_connect($db_host,$db_ user,$db pass); /| 连接 主机 
mysql_select_db($db_name,S$link); /选择 数据 库 
?> 


将 以 上 代码 保存 为 “21-1.php”， 以 便 在 以 后 的 具体 代码 中 调用 


21.3.2 ”安装 文件 的 创建 


该 配置 文件 。 


创建 程序 运行 所 需要 的 各 种 表 是 程序 运行 的 前 提 ， 这 一 小 节 就 来 实现 表 的 创建 。 以 下 代码 实现 的 
功能 是 先 让 用 户 输入 各 种 内 容 包括 注册 的 管理 员 信息 、 表 的 前 绥 等 信息 。 然 后 ， 在 后 台 获 取 用 户 提交 


的 内 容 ， 创 建 各 种 表 ， 并 为 用 户 表 插入 管理 员 的 信息 。 
下 面 给 出 详细 代码 : 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 安 装 程序 </title>\n"; 
echo "</head>\n"; 
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echo "<body>\n"; 
echo "<LINK href=\"style.css\" rel=stylesheet>\n"; 
if(!$_POST[admin]) // 如 果 没 有 默认 参数 ， 则 显示 HTML 


í 


echo "<script language=\"javascript\">\n"; 
echo "function juge(theForm)\n"; 
echo "An"; 

echo "\tif (theForm.admin.value 
echo "Win"; 

echo "tltalert(\" 请 输入 管理 员 名 称 ! Van" 

echo "\t\ttheForm.admin.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "Ma"; 

echo "tif (theForm.pass.value == \"\")\n"; 

echo "Win"; 

echo "t\talert(\" 请 输入 管理 员 密码 !\");\n"; 

echo "\t\ittheForm.pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "Ma"; 

echo "\tif (theForm.pass.value.length < 8 )\n"; 

echo "Win"; 

echo "t\talert(\" 密 码 至 少 要 8 位! \");\n"; 

echo "\t\ittheForm.pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "tn"; 

echo "tif (theForm.re_pass.value !=theForm.pass.value)\n"; 

echo \tN\n"; 

echo "titalert(\" 确 认 密 码 与 密码 不 一 致 !\");\n"; 

echo "“\t\ttheForm.re_pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "Min"; 

echo "tif (theForm.pre.value == \\")\n"; 

echo "Win"; 

echo "t\talert(\" 请 输入 表 前 缀 ! Van 

echo "\t\ttheForm.pre.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "tn"; 

echo "An"; 

echo "function s_photo(the)\n"; 

echo "An"; 

echo "\tdocument.img.src='images/'+the.photo.value+'.bmp';\n"; 

echo "Jn"; 

echo "</script>\n"; 

echo "<center>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 

echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)\">\n"; 
echo "<tr>\n"; 

echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 安 装 程序 </font></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 


Vn’ 


else 
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echo "<td> 管 理 员 : 〈 后 台 登 录 )</td>\n"; 
echo "<td><input type=\"text\" name=\"admin\"></td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 管 理 员 密码 : 〈 不 小 于 8 位 ) </td>\n'"; 
echo "<td><input type=\"password\" name=\"pass\" size=\"21\"></td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 确 认 密码 : </td>\n"; 
echo "<td><input type=\"password\" name=\"re_pass\" size=\"21\"></td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 管 理 员 E-mail: (CA) </td>\n"; 
echo "<td><input type=\"text\" name=\"email\"></td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 选 择 图 像 : </td>\n"; 
echo "<td>"; 
echo "<select name=\"photo\" size=\"1\" onchange=\"s_photo(this.form)\">\n"; 
for($i=1;$i<21;$i++) 
1 
echo "<option value=".$i.">".$i."</option>\n";; 
3 
echo "</select>"; 
echo "<img src=\"images/1.bmp\" name=\"img\">"; 
echo"</td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 表 的 前 缀 : </td>\n"; 
echo "<td><input type=\"text\" name=\"pre\" value=\"book_\"></td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td colspan=\"2\"><center>\n"; 
echo "<input type=\"submit\" value=\" F —#\">\n"; 
echo "<input type=\"reset\" value=\" 重 新 填 \">\n"; 
echo "</center></td>\n"; 
echo "</tr>\n"; 
echo "</form>\n"; 
echo "</table>\n"; 
echo "</center>\n"; 


echo "</body>\n"; 
echo "<html>\n"; 

// 如 果 有 POST 参数 ， 则 执行 操作 
$name=$_POST[admin]; // 获 得 参数 
$password=md5($_POST[pass]); // 获 得 密码 ， 并 使 用 MD5 进行 加 密 操 作 


$email=$_POST[email]; 
$photo=$_POST[photo]; 
$pre=$_POST[pre]; 


+479 。 


“480 PHP 网 络 编程 从 入 门 到 精通 


require "21-1.php"; 
$table_user=$pre.$table_user; 
$table_type=$pre.$table_type; 
$table_book=$pre.$table_book; 
$table_order=$pre.$table_order; 
$table_sale=$pre.$table_sale; 
$time=date("Y 4 m A d A"); 

$sql="create table $table user( 

id int(5) not null auto_increment primary key, 
name varchar(12) not null, 

password varchar(40) not null, 

photo varchar(80) not null, 

address varchar(80) not null, 

email varchar(80) not null, 

qq varchar(15) not null, 

msn varchar(80) not null, 

reg_date varchar(20) not null, 

post_num int(5) not null default 0, 

admin int(1) not null 

Yi 

mysql_query($sql,$link) or die(mysql_error()); /发 送 创建 user 表 的 SQL 请 求 
$sql="create table $table type( 

id int(5) not null auto_increment primary key, 
p_id int(5) not null, 

type_name varchar(12) not null, 
type_description varchar(80) not null, 

type num int(5) not null default 0 

六 

mysql_query($sql,$link) or die(mysql_error()); /发 送 创建 type 表 的 SQL 请 求 
$sql="create table $table book( 

id int(5) not null auto increment primary key, 
book name varchar(40) not null, 

book author varchar(20) not null, 

book pub varchar(40) not nuli, 

book type int(5) not null, 

book cost varchar(6) not null, 

book description varchar(200) not null, 

book photo varchar(80) not null, 

book sale num int(5) not null, 

book num int(5) not null 

Di 

mysql_query($sql,$link) or die(mysql_error()); /发 送 创建 book 表 的 SQL 请 求 
$sql="create table $table order( 

id int(5) not null auto_increment primary key, 
order user id int(5) not null, 

order user name varchar(12) not null, 
order book id int(5) not null, 

order book num int(5) not null, 

order content varchar(80) not null, 

order cost varchar(10) not null, 


yi; 
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order state enum('true','false') not null default 'false', 

order date varchar(40) not null 

六 

mysql_query($sql,$link) or die(mysql_error()); /发 送 创建 order 表 的 SQL 请 求 
$sql="create table $table_sale( 

id int(5) not null auto_increment primary key, 

sale_order_id int(5) not null, 

sale_date varchar(40) not null 

六 

mysql_query($sql,$link) or die(mysql_error()); /发 送 创建 sale 表 的 SQL 请 求 
$sql="insert into $table_type(p_id,type_name,type_description)values('0', 主 类 别 1',' 系 统 创建 的 默认 主 类 别 


mysql_query($sql,$link) or die(mysql_error()); /发 送 添加 默认 主 分 类 的 SQL 请 求 
$sql="insert into $table type(p_id,type_name,type_description)values('1',' 分 类 别 1',' 系 统 创建 的 默认 分 类 别 


mysql_query($sql,$link) or die(mysql_error()); // 发 送 添加 默认 子 分 类 的 SQL 请 求 
$sql="insert into 


$table user(name,password,photo,address,email,gg,msn,reg date,admin)values('$name','$password','$photo', 


"'$email' 


$time','3')"; 
mysql_query($sql,$link) or die(mysql_error()); /发 送 添加 管理 员 信 息 的 SQL 请 求 
$fp=fopen("21-1.php","w+"); // 将 更 新 过 的 数据 写 入 配置 文件 
fputs($fp,"<?\n"); 


fputs($fp,"\$db_host=\"localhost\";\n"); 

fputs($fp,"\$db_user=\"root\";\n"); 

fputs($fp,"\$db_pass=\"\";\n"); 

fputs($fp,"\$db_name=\"test\";\n"); 
fputs($fp,"\$table_user=\"$table_user";\n"); 
fputs($fp,"\$table_type=\"$table_type\";\n"); 
fputs($fp,"\$table_book=\"$table_book\";\n"); 
fputs($fp,"\$table_order=\"$table_order\";\n"); 
fputs($fp,"\$table_sale=\"$table_sale\";\n"); 
fputs($fp,"\$link=mysql_connect(\$db_host,\$db_user,\$db_pass);\n"); 
fputs($fp,"mysql_select_db(\$db_name,\$link);\n"); 

fputs($fp,"?>"); 

fclose($fp); 

echo "<center>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 

echo "<tr>\n"; 

echo "<td align=\"center\"><font size=\"5px\"> 安 装 程序 </font></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td align=\"center\"><font size=\"3px\"> 成 功 安装 ! </font></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td align=\"center\"><font size=\"3px\"> 删 除 该 文件 ， 以 减少 潜在 危险 ! </font></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td align=\"center\"> 点 <a href=\"21-5.php\"> 这 里 </a> 进 入 </td>\n"; 
echo "</tr>\n"; 

echo "</table>\n"; 
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echo "</center>"; 
echo "</body>\n"; 
echo “</html>\n"; 


} 
?> 


将 上 面 所 显示 的 代码 保存 为 “21-2.php”。 然 后 ， 在 PHP 执行 环境 下 执行 该 文件 ， 完 成 整个 系统 
运行 所 需要 的 各 种 表 的 创建 。 该 文件 执行 的 前 台 结果 如 图 21.1 所 示 。 


下 安装 程序 - icrosoft Internet Erplorer 
文件 中) MED FEV HEA TAM WHW 


安装 程序 
管理 员 ， (EBR) “J 
管理 员 密码 ， 《不 小 于 8 位 》 | EE 
AUE: E- 
管理 员 E-meil，《 可 选 ) C 
选择 图 像 : 
= 
表 的 前 绎 ， ook 
Tj an 
I ESE 


图 21.1 首次 运行 安装 文件 的 执行 结果 
按照 要 求 填 入 全 部 信息 ， 全 部 填写 完毕 单 击 “ 下 一 步 ” 按 钮 ， 将 出 现 如 图 21.2 所 示 的 执行 结果 。 


alo 
KAA BAD 查看 WD BRW IAD #HW |e 
到 | 

安装 程序 

成 功 安装 1 

WE, Kai 

点 这 里 进入 
到 
OOT Oiee 4 


图 21.2 安装 完成 执行 结果 
成 功 执行 安装 后 ， 系 统 运行 所 需要 的 表 创建 完毕 。 
随 着 安装 程序 正确 执行 完 安装 过 程 ， 系 统 实现 前 的 准备 工作 就 告 一 段落 。 从 21.4 节 开 始 就 将 通过 
具体 的 代码 来 实现 所 需 的 各 项 功能 。 


21.3.3” 头 文 件 的 创建 


这 一 节 来 创建 一 个 头 文件 ， 它 可 以 方便 的 链接 到 其 他 页 面 。 在 其 他 文件 中 调用 该 文件 ， 一 方面 可 
以 减少 代码 量 ， 另 一 方面 也 可 以 使 各 页 面 样式 保持 一 致 。 由 于 该 文件 输出 内 容 都 是 最 普通 的 HTML 内 
容 ， 所 以 不 过 多 解释 。 

下 面 给 出 具体 代码 : 
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<?php 

echo "<LINK href=\"style.css\" rel=stylesheet>\n"; 

echo "<center>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\" align=\"center\" bgcolor=\"#000000\">\n"; 
echo "<tr>\n"; 

echo "<td bgcolor=\"#cccc99\"><center><a href=\"21-5.php\"> 商 城 首 页 </a></center></td>\n"; 
echo "<td bgcolor=\"#cccc99\"><center><a href=\"21-6.php\"> 所 有 图 书 </a></center></td>\n"; 
echo "<td bgcolor=\"#cccc99\"><center><a href=\"21-7.php\"> 分 类 查看 </a></center></td>\n"; 
echo "<td bgcolor=\"#cccc99\"><center><a href=\"21-6.php\"> 图 书 搜索 </a></center></td>\n"; 
echo "<td bgcolor=\"#cccc99\"><center><a href=\"21-8.php\"> 管 理 入 口 </a></center></td>\n"; 
echo "</tr>\n"; 

echo "</table>\n"; 

echo "<p>"; 

?> 


把 以 上 代码 保存 为 “21-3.php”， 以 方便 其 他 页 面 的 调用 。 


21.4 用 户 的 注册 与 登录 


网 上 商城 也 需要 有 用 户 才 行 ， 用 户 是 各 类 商品 的 潜在 购买 者 。 所 以 ， 作 为 一 个 网 上 商城 系统 必须 
有 一 个 配套 的 用 户 注册 与 登录 系统 。 这 一 节 就 来 完成 用 户 的 注册 与 登录 功能 。 


21.4.1 用 户 注册 


用 户 注册 页 的 作用 是 给 出 一 个 用 户 界面 ， 要 求 用 户 输入 新 的 用 户 名 及 其 他 相关 信息 。 然 后 与 库 中 
所 保存 的 用 户 进行 比较 ， 如 果 用 户 名 已 经 存在 ， 则 给 出 出 错 提示 ; 反之 ， 就 提取 用 户 的 输入 信息 作为 
一 条 新 的 记录 写 入 到 表 中 。 

下 面 给 出 具体 代码 : 


<?php 
echo "<html>\n"; 
echo "<head>\n"; 
echo "<title> 注 册 新 用 户 </title>\n"; 
echo "</head>\n"; 
echo "<body>\n"; 
require "21-3.php"; 
if(!$_POST[user]) // 如 果 没 有 默认 参数 ， 则 显示 HTML 
{ 
echo "<script language=\"javascript\">\n"; 
echo "function juge(theForm)\n"; 
echo "An"; 
echo "\tif (theForm.user.value == \"\")\n"; 
echo "Win"; 
echo "t\talert(\" 请 输入 注册 用 户 名 ! Van 


echo "“\t\ttheForm.user.focus();\n"; 
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echo "\t\treturn (false);\n"; 

echo "thn"; 

echo "\tif (theForm.pass.value == \"\")\n"; 

echo "itin"; 

echo "Mai "AA A E Van 

echo "\t\ttheForm.pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "thn"; 

echo "\tif (theForm.pass.value.length < 8 Jan"; 

echo "Win"; 

echo "t\talert(\" 密 码 至 少 要 8 位 ! \");\n"; 

echo "\t\ittheForm.pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "Man"; 

echo "tif (theForm.re_pass.value !=theForm.pass.value)\n"; 
echo "Win"; 

echo "titalert(\" 确 认 密 码 与 密码 不 一 致 !\");\n"; 

echo "\t\ittheForm.re_pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "Mha"; 

echo "tif (theForm.address.value == \"\")\n"; 

echo "Win"; 

echo "titalert(\" 请 输入 用 户 地 址 ! VAT 

echo "“t\ttheForm.address.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "An"; 

echo "}\n"; 

echo "function s_photo(the)\n"; 

echo "An"; 

echo "\tdocument.img.src='images/'+the.photo.value+'.bmp';\n"; 
echo "An"; 

echo "</script>\n"; 

echo "<center>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)\">\n"; 
echo "<tr>\n"; 

echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 注 册 新 用 户 </font></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 用 户 名 : 〈 后 台 登 录 ) </td>\n"; 

echo "<td><input type=\"text\" name=\"usen\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<t> AAEE: 〈 不 小 于 8 位 )</td>\n"; 

echo "<td><input type=\"password\" name=\"pass\" size=\"21\"></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 确 认 密码 : </td>\n"; 

echo "<td><input type=\"password\" name=\"re_pass\" size=\"21\"></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 


else 
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echo "<td> 用 户 E-mail: 〈 可 选 ) </td>\n"; 

echo "<td><input type=\"text\" name=\"email\"></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td>Q Q 号 : (可 选 ) </td>\n"; 

echo "<td><input type=\"text\" name=\"qq\"></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td>M S N 号 ;: (可 选 ) </td>\n"; 

echo "<td><input type=\"text\" name=\"msn\"></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 选 择 图 像 : </td>\n"; 

echo "<td>"; 


echo "<select name=\"photo\" size=\"1\" onchange=\"s_photo(this.form)\">\n"; 


for($i=1;$i<21;$i++) 
{ 
echo "<option value=".$i.">".$i."</option>\n";; 
} 
echo "</select>"; 
echo "<img src=\"images/1.bmp\" name=\"img\">"; 
echo"</td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 用 户 地 址 :</td>\n"; 
echo "<td><input type=\"text\" name=\"address\"></td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td colspan=\"2\"><center>\n"; 
echo "<input type=\"submit\ value=\" F —#\">\n"; 
echo "<input type=\"reset\" value=\" 重 新 填 \">\n"; 
echo "</center></td>\n"; 
echo "</tr>\n"; 
echo "</form>\n"; 
echo "</table>\n"; 
echo "</center>\n"; 
echo "</body>\n"; 
echo "<html>\n"; 


$user=$_POST[user]; 
$pass=md5($_POST[pass]); 
$email=$_POST[email]; 
$msn=$_POST[msn]; 
$qq=$_POST[qq]; 
$photo=$_POST[photo].".bmp"; 
$address=$_POST[address]; 
$time=date("Y 年 m 月 d A"); 
require "21-1.php"; 
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$sql="select id from $table user where name='$user "; 
$result=mysql_query($sql,$link) or die(mysql_error()); 
$nums=mysql_num_rows($result); 
if($nums!=0) 
{ 
echo "<center>"; 
echo "<h2> 注 册 的 用 户 名 ".$user." 已 经 存在 ! </h2>"; 
echo "<h3> 请 点 <a href=# onclick=history.go(-1)> 这 里 </a> 返 回 ， 重 新 输入 新 的 用 户 名 ! </h3>"; 
echo "</center>"; 


exit(); 
} 
else 
{ 
$sql="insert into 


$table_user(name,password,email,photo,msn,qq,address,reg_date)values('$user','$pass','$email','$photo','$ms 
n','$qq','$address','$time')"; 

mysql_query($sql, $link) or die(mysql_error()); 

echo "<center>"; 

echo "<h2> 新 用 户 ".$user." 注 册 成 功 ! </h2>"; 

echo "<h3> 点 <a href=21-5.php> 这 里 </a> 进 行 登录 ! </h3>"; 

echo "</center>"; 


} 

?> 

把 以 上 代码 保存 为 “21-4.php”。 其 执行 过 程 相对 简单 ， 这 里 也 不 再 演示 。 可 以 参看 以 前 章节 中 其 
他 类 似 的 内 容 。 


214.2 用 户 登录 


用 户 注册 后 ， 如 果 不 登 录 系 统 ， 还 是 和 匿名 用 户 没有 区 别 。 只 有 登录 了 系统 ， 才 能 拥有 匿名 用 户 
所 没有 的 权限 ， 比 如 购买 图 书 等 。 用 户 登 录 的 道理 也 很 简单 ， 判 断 用 户 名 与 密码 ， 如 果 与 表 中 存在 记 
录 相 同 ， 则 把 用 户 名 和 ID 写 入 Cookie; 反之 ， 给 出 出 错 提示 并 要 求 重 输 。 在 用 户 成 功 登录 后 ， 再 跳 转 
到 指定 页 面 即 可 。 

具体 内 容 请 参看 以 下 代码 : 

<?php 

if($_COOKIE[user]) 


echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 注 册 用 户 已 经 登录 </title>\n"; 

echo "</head>\n"; 

echo "<body>\n"; 

require "21-3.php"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>\n"; 
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echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 注 册 用 户 管 理 </font></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td><a href=\"21-11.php\"> 修 改 用 户 信息 </a></td>\n"; 
echo "<td><a href=\"21-12.php\"> 修 改 用 户 密码 </a></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td><a href=\"21-19.php\"> 查 看 我 的 购物 车 </a></td>\n"; 
echo "<td><a href=\"21-20.php\"> 查 看 我 的 历史 订单 </a></td>\n"; 
echo "</tr>\n"; 

echo "</table>"; 

echo "<br>"; 

require "21-1.php"; 

$sql="select admin from $table user where id='$_COOKIE[id]"; 
$result=mysql_query($sql,$link); 
$rows=mysql_fetch_array($result); 

if($rows[0]==3) 


{ 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>\n"; 
echo "<td colspan=\"2\" align=Vcenten"><font size=\"5px\"> 商 品 管理 </font></td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td><a href=\"21-13.php\"> 增 加 新 的 类 别 </a></td>\n"; 
echo "<td><a href=\"21-14.php\"> 修 改 已 有 分 类 </a></td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td><a href=\"21-15.php\"> 增 加 新 的 商品 </a></td>\n"; 
echo "<td><a href=\"21-16.php\"> 修 改 已 有 商品 </a></td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td><a href=\"21-17.php\"> 查 看 订单 </a></td>\n"; 
echo "<td><a href=\"21-18.php\"> 销 售 记 录 </a></td>\n"; 
echo "</tr>\n"; 
echo "</table>\n"; 
} 
echo "</center>\n"; 
echo "</body>\n"; 
echo "<html>\n"; 
exit(); 
} 
if(1$ POSTluser)) // 如 果 没 有 默认 参数 ， 则 显示 HTML 
echo "<html>\n"; 
echo "<head>\n"; 
echo "<title> 注 册 用 户 登 录 </title>\n"; 
echo "</head>\n"; 
echo "<body>\n"; 


require "21-3.php"; 
echo "<script language=\"javascript\">\n"; 
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echo "function juge(theForm)in"; 

echo "Nn"; 

echo "tif (theForm.user.value == \"\")\n"; 

echo "tfn"; 

echo "ttalert(\ 请 输入 用 户 名 ! \");\n"; 

echo "t\ttheForm.user.focus();\n"; 

echo "Wtreturn (false);\n"; 

echo "itn"; 

echo "tif (theForm.pass.value == \"\")\n"; 

echo "itin"; 

echo "t\talert(\" 请 输入 用 户 密码 !\");\n"; 

echo "\t\ittheForm.pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "An"; 

echo "An"; 

echo "</script>\n"; 

echo "<center>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<form method=\"post\" action=\"$PATH_INFO\ onsubmit=\"return juge(this)\">\n"; 
echo "<tr>\n"; 

echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 注 册 用 户 登 录 </font></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 用 户 名 :</td>\n"; 

echo "<td><input type=\"text\" name=\"usen\"></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 用 户 密码 : </td>\n"; 

echo "<td><input type=\"password\" name=\"pass\" size=\"21\"></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 选 择 COOKIE 有 效 期 : </td>\n"; 

echo "<td>"; 

echo "<select name=\"cook_t\" size=\"1\">\n"; 

echo "<option value=\"1\"> 最 短 时 效 </option>"; 

echo "<option value=\"2\">1 天 </option>"; 

echo "<option value=\"3\">1 月 </option>"; 

echo "<option value=\"4\">1 年 </option>"; 

echo "</select>"; 

echo"</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td colspan=\"2\"><center>\n"; 

echo "<input type=\"submit\" value=\" 下 一 步 \*>\n"; 
echo "<input type=\"reset\" value=\" 重 新 填 \">\n"; 

echo "</center></td>\n"; 

echo "</tr>\n"; 

echo "</form>\n"; 

echo "</table>\n"; 

echo "</center>\n"; 


else 
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echo "</body>\n"; 
echo "<html>\n"; 


$user=$_POST[user]; 

$pass-md5($ POSTIpass)); 

$cook_t=$_POST[cook_t]; 

require "21-1.php"; 

$sql="select id from $table user where name='$user and password='$pass"; 
$result=mysql_query($sql, $link) or die(mysql_error()); 
$nums=mysql_num_rows($result); 

if($nums==0) 


{ 


else 


echo "<center>"; 

echo "<h2> 输 入 的 用 户 名 或 者 密码 错误 ! </h2>"; 

echo "<h3> 请 点 <a href=# onclick=history.go(-1)> 这 里 </a> 返 回 重新 输入 ! </h3>"; 
echo "</center>"; 

exit(); 


$rows=mysql_fetch_array($result); 
$id=$rowsfid]; 
if($cook_t==1) // 根 据 不 同 的 COOKIE 设 定时 间 保存 COOKIE 
{ 
setcookie("user","$user"); 
setcookie("id","$id"); 


} 

elseif($cook_t==2) 

{ 
setcookie("user","$user" ,time()+60*60*24); 
setcookie("id","$id",time()+60*60*24); 

} 

elseif($cook_t==3) 

{ 
setcookie("user","$user",time()+60*60*24*30); 
setcookie("id","$id",time()+60*60*24*30); 

} 

else 

{ 
setcookie("user","$user",time()+60*60*24*30*360); 
setcookie("id","$id",time()+60*60*24*30*360); 

} 


echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 注 册 用 户 登录 <l/title>\n"; 
echo "</head>\n"; 

echo "<body>\n"; 
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require "21-3.php"; 

echo "<h2> 用 户 ".$user." 登 录 成 功 ! </h2>"; 

echo "<h3> 两 秒 后 进入 商城 首页 面 ! </h3>"; 

echo "<meta http-equiv=\"refresh\" content=\"2; url=21-6.php\">"; 
echo "</center>"; 


} 
?> 


将 上 述 代 码 保存 为 “21-5.php”， 以 备用 户 登录 之 用 。 由 于 用 户 登 录 过 程 也 比较 简单 ， 这 里 也 不 再 
给 出 演示 。 如 果 要 浏览 相似 的 执行 结果 ， 请 查看 本 书 第 20 章 相关 内 容 即 可 。 


21.5 前 台 显 示 界 面 


这 一 节 来 完成 所 用 的 前 台 界 面 ， 即 普通 用 户 能 够 看 到 的 界面 。 其 中 包括 首页 页 面 、 图 书 列表 页 面 、 
按 种 类 查看 页 面 、 某 一 图 书 详细 情况 页 面 、 购 物 车 的 实现 等 。 
下 面 就 来 一 个 一 个 地 实现 这 些 所 需 功能 。 


21.5.1 首页 面 的 实现 


首页 面 是 用 户 进入 系统 后 看 到 的 第 1 个 页 面 ， 是 进入 其 他 页 面 的 前 提 。 这 一 节 来 完成 系统 首页 面 
的 设计 。 该 首页 面包 括 以 下 内 容 : 用 户 登 录 的 接口 、 总 图 书 数 、 注 册 用 户 人 数 、 图 书 的 分 类 查看 、 最 
新 添加 的 图 书 、 图 书 的 搜索 界面 等 。 由 于 包括 内 容 比 较 多 ， 所 以 说 首页 面 也 是 一 个 相对 复杂 的 页 面 。 
下 面 给 出 具体 的 代码 来 实现 这 些 内 容 的 显示 。 代 码 如 下 : 


<?php 
echo "<html>\n"; 
echo "<head>\n"; 
echo "<title> 网 上 图 书 商城 首页 </title>\n"; 
echo "</head>\n"; 
echo "<body>\n"; 
echo "<center>\n"; 
require "21-3.php"; 
echo "<table width=80%>\n"; 
echo "<tr>\n"; 
echo "<td width=\"20%\">\n"; 
if(!$_COOKIE[user]) /如 果 没 用 用 户 登 录 ， 则 显示 HTML 
{ 
echo "<script language=\"javascript\">\n"; 
echo "function juge(theForm)\n"; 
echo "An"; 
echo "\tif (theForm.user.value == \"\")\n"; 
echo "Win"; 
echo "titalert(\" 请 输入 用 户 名 ! Van 
echo "“\t\ttheForm.user.focus();\n"; 


else 
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echo "\t\treturn (false);\n"; 

echo "itn"; 

echo "\tif (theForm.pass.value == \"\")\n"; 
echo "itin"; 

echo "t\talert(\" 请 输入 用 户 密码 !\");\n"; 
echo "\t\ttheForm.pass.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "thn"; 

echo "An"; 

echo "function juge2(theForm)\n"; 

echo "An"; 

echo "\tif (theForm.search c.value == \"\")\n"; 
echo "Win"; 

echo "\t\talert(\" 请 输入 搜索 内 容 ! \");\n"; 
echo "“t\ttheForm.search_c.focus();\n"; 
echo "\t\treturn (false);\n"; 

echo "tn"; 

echo "An"; 

echo "</script>\n"; 

echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\">\n"; 

echo "<form method=\"post\" action=21-5.php onsubmit=\"return juge(this)\">\n"; 

echo "<tr>"; 

echo "<td><center> 用 户 登录 </center></td>\n"; 

echo "</tr>\n"; 

echo "<tr>"; 

echo "<td> 用 户 名 : "; 

echo "<input type=\"text\" name=\"usen\" size=\"6\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 密 &nbsp;&nbsp; 码 : "; 

echo "<input type=\"password\" name=\"pass\" size=\"5\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td><center>\n"; 

echo "<td><center><a href=\"21-4.php\"> 注 册 </a>\n<input type=\"submit\" value=\" 登 录 \">\n"; 
echo "</center></td>\n"; 

echo "</tr>\n"; 

echo "</form>"; 

echo "</table>"; 


// 如 果 有 用 户 登录 ， 则 显示 操作 连接 


echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\">\n"; 

echo "<tr>"; 

echo "<td> 登 录用 户 : ".$_COOKIE[user]."</td>\n"; 

echo "</tr>\n"; 

echo "<tr>"; 

echo "<td><center><a href=\"21-15.php\"> 退 出 登录 </a></center></td>\n"; 
echo "</tr>\n"; 

echo "</table>"; 
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} 

echo "<br>"; 

echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\">\n"; 
echo "<tr>"; 

echo "<td><center> 本 站 信息 </center></td>\n"; 

echo "</tr>\n"; 

echo "<tr>"; 

echo "<td> 共 有 用 户 : "; 

require "21-1.php"; 

$sql="select id from $table_user"; 
$result=mysql_query($sql,$link); 
$num=mysql_num_rows($result); 

echo $num; 

echo "名 </td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 共 有 图 书 :"; 

$sql="select id from $table book"; 
$result=mysql_query($sql,$link); 
$num=mysql_num_rows($result); 

echo $num; 

echo "种 </td>\n"; 

echo "</tr>\n"; 

echo "</table>"; 

echo "<br>"; 

echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\">\n"; 
echo "<tr>"; 

echo "<td> 最 新 用 户 : "; 

$sql="select name from $table user order by id desc"; 
$result=mysql_query($sql,$link); 
$rows=mysql_fetch_array($result); 

echo $rows[0]; 

echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 最 新 图 书 : "; 

$sgl-"select * from $table book order by id desc"; 
Sresult=mysql_query($sql,$link); 
$rows=mysql_fetch_array($result); 

echo "<a href=21-10.php?id=".$rows[id].">".$rows[book_name]."</a>"; 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "</table>"; 

echo "<br>"; 

echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\">\n"; 
echo "<tr>"; 

echo "<td> 图 书 分 类 :</td>\n"; 

echo "</tr>\n"; 

$sql2="select * from $table type where p_id!=0"; 
$result2=mysql_query($sql2,$link); 
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while($rows2=mysql_fetch_array($result2)) 


{ 
echo "<tr>\n"; 
echo "<td>"; 
echo "<a href=21-8.php?id=".$rows2[id].">".$rows2[type_name]."</a>: (".$rows2[type_num].") "; 
echo "</td>\n"; 
echo "</tr>\n"; 
} 
echo "</table>"; 
echo "</td>\n"; 


echo "<td width=\"80%\">\n"; 

echo "<script language=\"javascript\">"; 
echo "function juge2(theForm)\n"; 
echo "An"; 

echo "\tif (theForm.search_c.value 
echo "Win"; 

echo "ttalert(\" 请 输入 搜索 内 容 ! "An"; 

echo "\tittheForm.search_c.focus();\n"; 

echo "ttreturn (false);\n"; 

echo "Wh"; 

echo "An"; 

echo "</script>\n"; 

echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\" height=\"100%\">\n"; 
echo "<tr>"; 

echo "<form method=\"post\" action=\"21-9.php\" onsubmit=\"return juge2(this)\">\n"; 
echo "<td> 搜 索 图 书 </td>\n"; 

echo "<td> 搜 索 内 容 :"; 

echo "<input type=\"text\" name=\"search_c\" size=\"6\">"; 

echo "搜索 类 型 :"; 

echo "<select name=\"search_t\" size=\"1\">\n"; 

echo "<option value=\"book_name\"> 书 名 </option>"; 

echo "<option value=\"book_authorW> 作 者 </option>"; 

echo "<option value=\"book_pub\"> 出 版 社 </option>"; 

echo "</select>"; 

echo "<input type=\"submit\" value=\" 搜 索 \*>\n"; 

echo "</td>\n"; 

echo "</form>\n"; 

echo "</tr>\n"; 

echo "</table>"; 

echo "<br>"; 

echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\">\n"; 

if($num!=0) 

{echo "<tr>"; 

echo "<td colspan=\"2\"> 最 新 推荐 图 书 </td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td width=\"30%\"> 图 书 名 称 : </td>\n"; 

echo "<td>".$rows[book_name]."</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 
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echo "<td> 图 书 作 者 : </td>\n"; 

echo "<td>".$rows[book_author]."</td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 出 版 社 : </td>\n"; 

echo "<td>".$rows[book_pub]."</td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 售 价 : </td>\n"; 

echo "<td>".$rows[book_cost]." 元 </td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 所 属 类 别 : </td>\n"; 

echo "<td>".$rows[book_type]."</td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 该 书 的 数量 : </td>\n"; 

echo "<td>".$rows[book_num]." 本 </td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 该 书 的 简介 : </td>\n"; 

echo "<td>".$rows[book_description]."</td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 该 书 的 封面 扫描 图 : </td>\n"; 
echo "<td>"; 

if(!$rows[book_photo]) 

{ 


} 

echo "<img src=\"".$rows[book_photo]."\">"; 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "</table>"; 

echo "</td>\n"; 

echo "</tr>\n"; 

} 


else 


{ 


$rows[book_photo]="images/nopic.gif"; 


echo "<tr>\n"; 
echo "<td> 暂 时 没有 推荐 图 书 </td>\n"; 
echo "</tr>\n"; 

} 

echo "</table>\n"; 

echo "</center>\n"; 

echo "</body>\n"; 

echo "</html>\n"; 

?> 
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把 上 述 代码 保存 为 “21-6.php”， 首 页 面 创 建 ET = zE 
完毕 。 首 先 在 首页 用 管理 员 身份 进行 登录 。 首 页 e e D 
将 会 出 现 如 图 21.3 所 示 的 结果 ， 也 说 明 该 程序 正 [| 
常 运行 con Hsm eam TE 
m IZT o EA EN 
景 新 推荐 图 书 
21.5.2 ”图 书 列表 页 面 的 实现 | 
图 21.3 管理 员 登 录 后 的 首页 执行 结果 
图 书 列表 页 面 ， 按 照 添加 日 期 的 先后 ， 显 示 
出 所 有 图 书 表 中 的 记录 ， 如 果 记录 数 超过 了 每 页 显示 数 ， 则 分 页 显示 。 显 示 信 息 有 : 书 名 、 作 者 、 简 


介 《〈 如 果 简 介 太 长 ， 则 截取 其 部 分 显示 ) o 


下 面 是 具体 代码 内 容 : 
<?php 

echo "<html>\n"; 

echo "<head>\n"; 


echo "<title> 查 看 所 有 图 书 </title>\n"; 

echo "</head>\n"; 

echo "<body>\n"; 

echo "<center>\n"; 

require "21-3.php"; 

require "21-1.php"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 


$sql="select id from $table book"; /从 列表 中 读 出 所 有 图 书记 录 
$result=mysql_query($sql,$link) or die(mysql_error()); /发 送 查找 列表 请 求 
$num=mysql_num_rows($result); // 获 取 结 果 条 数 
$p_count=ceil($num/10); /总 页 数 


if ($_GET["page"]==0 && !$_GET["page"]) $page=1;// 当 前 页 
else $page=$_GET["page"]; 


if($num<1) // 如 果 没 有 记录 
{ 
echo "<tr>\n"; 
echo "<td>"; 
echo "<center><h2> 暂 时 还 没有 图 书 的 记录 </h2></center>"; /| 输出 相应 信息 
echo "</td>\n"; 
echo "</tr>\n"; 
exit(); // 退 出 所 有 PHP 代码 
} 
else // 如 果 有 记录 ， 则 执行 相应 操作 
{ 


$s=($page-1)*10; 

$sql="select * from $table book order by id limit $s,10"; 
$result=mysql_query($sql,$link); 

echo "<tr>\n"; 

echo "<td> 书 名 </td>\n"; 

echo "<td> 作 者 </td>\n"; 

echo "<td> 价 格 </td>\n"; 

echo "<td> 类 别 </td>\n"; 
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echo "<td> 简 介 </td>\n"; 
while($rows=mysql_fetch_array($result)) // 循 环 显示 记录 内 容 
{ 
echo "<tr>\n"; 
echo "<td><a href=\"21-10.php?id=". $rows[id]."\">".$rows[book_name]."</a></td>\n"; // 显 示 书 名 
echo "<td>".$rows[book_author]."</td>\n";// 显 示 作 者 
echo "<td>".$rows[book_cost]."</td>\n";”// 显 示 价 格 
$sql2="select id,type_name from $table type where id='$rows[book_type]"; 
$result2=mysql_query($sql2,$link); 
$rows2=mysql_fetch_array($result2); 
echo "<td><a href=\"21-8.php?id=".$rows2[0]."\">".$rows2[1]."</a></td>"; /显示 类 别 
if(strlen($rows[book_description])>100) 
Srows[book_description]=substr($rows[description],0,100); 
echo "<td>".$rows[book_description]."</td>\n"; 
echo "</tr>\n"; 
} 
} 
echo "</table>"; 
/以 下 为 分 页 显示 内 容 
$prev_page=$page-1; 
S$next_page=$page+1; 
echo" <p align=\Vcenten"> "; 
if ($page>1) 
1 


} 
if ($prev_page>=1) 
{ 


} 
if ($next_page<=$p_count) 


{ 


} 
if ($page<$p_count) 
{ 


} 

echo "</center>"; 
echo "</body>"; 
echo "</html>"; 
?> 


把 以 上 代码 保存 为 “21-7.php”， 以 便 用 户 查看 所 有 记录 时 调 有 
单 ， 不 再 给 出 效果 图 。 


echo "<a href='$PATH_INFO?page=1'> 第 一 页 </a> | "; 


echo "<a href='$PATH_INFO?page=$prev_page'> 上 一 页 </a> | "; 


echo "<a href='$PATH_INFO?page=$next_page'> 下 一 页 </a> |" 


echo "<a href='$PATH_INFO?page=$p_count> 最 后 一 页 </a></p>\n"; 


该 文件 。 该 PHP 执行 机 理 相 当 简 


21.5.3” 按 种 类 查看 页 面 


该 页 面 显示 图 书 的 所 有 种 类 ， 并 且 在 每 个 子 种 类 上 都 有 指向 该 种 类 查看 页 面 的 超 链接 ， 用 户 只 需 
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要 单 击 该 超 链接 ， 就 可 以 实现 查看 该 种 类 下 的 所 有 图 书 。 

这 里 把 所 有 种 类 的 显示 与 某 一 种 类 的 单独 显示 功能 整合 到 了 一 个 页 面 。 用 一 个 参数 来 判断 要 显示 
哪 一 类 。 如 果 没 有 任何 参数 ， 则 显示 所 有 种 类 ; 如 果 指定 了 参数 ID， 则 显示 某 一 类 的 结果 。 

下 面 给 出 具体 代码 : 


<?php 
echo "<html>\n"; 
echo "<head>\n"; 
echo "<title> 按 种 类 查看 图 书 </title>\n"; 
echo "</head>\n"; 
echo "<body>\n"; 
echo "<center>\n"; 
require "21-3.php"; 
if(!$_GETI[id]) 
t 
echo "<font size=5> 查 看 所 有 种 类 </font>"; 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
require "21-1.php"; 
$sql="select * from $table_type where p_id=0"; 
$result-mysg! guery($sgl,$link); 
while($rows=mysql_fetch_array($result)) // 循 环 显示 主 类 别 
{ 
echo "<tr>\n"; 
echo "<td colspan=\"2\">"; 
echo $rows[type_name]; 
echo " (".$rows[type_num].") "; 
echo "</td>\n"; 
echo "</tr>\n"; 
$i=0; 
$sql2="select * from $table type where p id-'$rowslid)' and id>'$rows[id]"; 
$result2=mysql_query($sql2,$link) or die(mysgl error()); 
$m_count=mysql_num_rows($result2); 
while($rows2=mysql_fetch_array($result2)) /循环 显示 主 类 别 下 的 分 类 别 
{ 
if($i%2==0) echo "<tr>\n"; 
echo "<td width=\"50%\">"; 
echo "<a href=21-8.php?id=".$rows2[id].">".$rows2[type_name]."</a>"; 
echo " (".$rows2[type_num].") "; 
echo "</td>\n"; 
$i++; 
if(($m_count%2==1) and $i==($m_count)) 
echo "<td>&nbsp;</td>"; 
if($i%2==1) echo "</tr>\n"; 


else 


require "21-1.php"; 


/显示 
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$sql="select type name from $table type where id='$_GET[id]"; 
$result=mysql_query($sql,$link); 
$type_name=mysql_fetch_array($result); 
echo "<font size=5> 查 看 种 类 : ".$type_name[0]."</font>"; 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
$sql="select * from $table book where book_type='$_GET[id] order by id desc"; /从 列表 中 读 出 所 有 图 
书记 录 
$result=mysql_query($sql,$link) or die(mysql_error()); /发 送 查 找 列表 请 求 
$num=mysql_num_rows(S$result); // 获 取 结 果 条 数 
$p_count=ceil($num/10); /总 页 数 
if ($_GET["page"]==0 && !$_GET["page"]) $page=1;// 当 前 页 
else $page=$_GET["page"]; 
if($num<1) // 如 果 没 有 记录 
{ 
echo "<tr>\n"; 
echo "<td>"; 
echo "<center><h2> 暂 时 还 没有 图 书 的 记录 </h2></center>"; // 输 出 相应 信息 
echo "</td>\n"; 
echo "</tr>\n"; 
exit(); // 退 出 所 有 PHP 代码 
$ 
else // 如 果 有 记录 ， 则 执行 相应 操作 
1 
echo "<tr>\n"; 
echo "<td> 书 名 </td>\n"; 
echo "<td> 作 者 </td>\n"; 
echo "<td> 价 格 </td>\n"; 
echo "<td> 类 别 </td>\n"; 
echo "<td> 简 介 </td>\n"; 
while($rows=mysql_fetch_array($result) // 循 环 显示 记录 内 容 
{ 
echo "<tr>\n"; 
echo "<td><a href=\"21-10.php?id=".$rows[id]."\">".$rows[book_name]."</a></td>\n"; 
书 名 


echo "<td>".$rows[book_authonl."</td>\n";// 显 示 作者 
echo "<td>".$rows[book_cost]."</td>\n"; /显示 价格 
$sql2="select type name from $table type where id-'$rows|book type)"; 
$result2=mysql_query($sql2); 
$rows2=mysql_fetch_array($result2); 
echo "<td>". $rows2[0]."</td>"; // 显 示 类 别 
if(strlen($rows[book_description])>100) 
$rows[book_description]=substr($rows[description],0,100); 
echo "<td>". $rows[book_description]."</td>\n"; 
echo "</tr>\n"; 
} 
} 
echo "</table>"; 
/以 下 为 分 页 显示 内 容 
$prev_page=$page-1; 
$nert page-$paget1; 
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echo" <p align=\"centerñ"> "; 

if ($page>1) 

t echo "<a href='$PATH_INFO?page=1'> 第 一 页 </a> |" 

i ($prev_page>=1) 

t echo "<a href='$PATH_INFO?page=$prev_page'> 上 一 页 </a> |" 
i ($next_page<=$p_count) 

echo "<a href='$PATH_INFO?page=$next_page> 下 一 页 </a> |" 
} 


if ($page<$p_count) 
{ 


echo "<a href='$PATH_INFO?page=$p_count> 最 后 一 页 </a></p>\n"; 


echo "</center>"; 
R A DEMEDEN Diervnoft Tatormet Paplorer 
echo "</body>"; (zmo anao sav erw IRAD DW 


echo "</html>"; EREN | FAEH | AXHA | HERA | EmO Jl 
2 TRT 查看 所 有 种 类 
把 此 代码 保存 为 “21-8.php”， 以 方便 用 户 查 0 
看 类 别 时 调用 该 文件 。 在 PHP 环境 中 执行 该 文件 EANA Fl 


〈 前 提 是 以 管理 员 身 份 登录 系统 并 添加 了 相应 类 
别 及 图 书 ) ， 其 执行 结果 如 图 21.4 所 示 。 图 21.4 查看 所 有 分 类 执行 结果 


2154 搜索 图 书页 面 


如 果 图 书 的 种 类 太 多 ,给 用 户 提供 一 个 搜索 的 平台 是 有 必要 的 。 用 户 可 以 按照 图 书 的 名 称 、 作 者 、 
出 版 社 、 及 所 属 类 型 等 各 项 信息 来 查找 相应 的 目标 图 书 。 如 果 找 到 了 相应 的 图 书 ， 就 循环 显示 所 有 查 
找 结 果 ， 并 给 出 相应 的 查看 该 书 详情 的 链接 。 

下 面 是 实现 搜索 功能 的 具体 代码 : 


<?php 
echo "<html>\n"; 
echo "<head>\n"; 
echo "<title> 图 书 搜索 </title>\n"; 
echo "</head>\n"; 
echo "<body>\n"; 
require "21-3.php"; 
if(!$_POST[search_c]) /如 果 没 有 默认 参数 ， 则 显示 HTML 
f 
echo "<script language=\"javascript\">\n"; 
echo "function juge(theForm)\n"; 
echo "An"; 


500" 


else 
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echo "tif (theForm.search c.value == \"\")\n"; 

echo "Win"; 

echo wttalert(\" 请 输入 搜索 内 容 ! \");\n"; 

echo "\t\ttheForm.search_c.focus();\n"; 

echo "\t\treturn (false);\n"; 

echo "itn"; 

echo "Jn"; 

echo "</script>\n"; 

echo "<center>\n"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)\">\n"; 
echo "<tr>\n"; 

echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 图 书 搜索 </font></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 输 入 搜索 内 容 : </td>\n'"'; 

echo "<td><input type=\"text\" name=\"search_c\"></td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 选 择 搜索 类 型 :</td>\n"; 

echo "<td>"; 

echo "<select name=\"search_t\" size=\"1\">\n"; 

echo "<option value=\"book_name\"> 书 名 </option>"; 

echo "<option value=\"book_authon\"> 作 者 </option>"; 

echo "<option value=\"book_pub\"> 出 版 社 </option>"; 

echo "</select>"; 

echo"</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 选 择 搜索 模式 :</td>\n"; 

echo "<td>"; 

echo "<input type=\"radio\" name=\"search_m\" value=\"1\" checked> 精 确 查找 "; 
echo "<input type=\"radio\" name=\"search_m\" value=\"2\"> 模 糊 查 找 "; 
echo"</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td colspan=\"2\"><center>\n"; 

echo "<input type=\"submit\" value=\" 下 一 步 \*>\n"; 

echo "<input type=\"reset\" value=\" 重 新 填 \">\n"; 

echo "</center></td>\n"; 

echo "</tr>\n"; 

echo "</form>\n"; 

echo "</table>\n"; 

echo "</center>\n"; 

echo "</body>\n"; 

echo "<html>\n"; 


require "21-1.php"; /1 调用 配置 文件 
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$search_c=$_POST[search_c]; // 获 取 表 单 变量 
$search t=$_POSTI[search 1]; 
$search_m=$_ POSTI(search mj; 


if($search_m=="1") // 根 据 搜索 模式 的 不 同 设置 不 同 的 搜索 类 型 
{ 
$sql="select * from $table book where $search_t='$search_c"; 
} 
else 
{ 
$sql="select * from $table book where $search t like '$search_c"; 
} 
$result=mysql_query($sql,$link); // 发 送 SQL 请 求 
$num=mysql_num_rows(S$result); // 获 取 结 果 数 
if($num<1) // 如 果 没 有 结果 ， 则 显示 内 容 
{ 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<tr>\n"; 
echo "<td align=\Vcenten"><font size=\"5px\"> 图 书 搜索 </font></td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td align=\center\"> 对 不 起 没有 找到 你 所 要 求 的 内 容 ! </td>\n"; 
echo "</tr>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td align=\Vcenter"> 点 <a href=# onclick=history.go(-1)> 这 里 </a> 返 回 </td>\n"; 
echo "</tr>\n"; 
echo "</table>"; 
$ 
else // 如 果 有 结果 ， 则 循环 显示 内 容 
{ 


echo " 共 找到 ".$num." 条 记录 "; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 

echo "<tr>\n"; 

echo "<td> 书 名 </td>\n"; 

echo "<td> 作 者 </td>\n"; 

echo "<td> 价 格 </td>\n"; 

echo "<td> 类 别 </td>\n"; 

echo "<td> 简 介 </td>\n"; 

while($rows=mysql_fetch_array($result)) 

{ 
echo "<tr>\n"; 
echo "<td><a href=\"21-10.php?id=".$rows[id]."\">".$rows[book_name]."</a></td>\n"; // 显 示 书 名 
echo "<td>".$rows[book_author]."</td>\n";// 显 示 作 者 
echo "<td>".$rows[book_cost]."</td>\n"; /显示 价格 
$sql2="select type name from $table type where id='$rows[book_type]"; 
$result2=mysql_query($sql2); 
$rows2=mysql_fetch_array($result2); 
echo "<td>". $rows2[0]."</td>"; // 显 示 类 别 
if(stren($rows[book_description])>100) 
$rows[book_description]=substr($rows[description],0, 100); 
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echo "<td>". $rows[book_description]."</td>\n"; 
echo "</tr>\n"; 


echo "</table>"; 


} 
echo "</center>"; 
echo "</body>"; 
echo "</html>"; 

} 

?> 


将 以 上 代码 保存 为 “21-9.php”。 这 样 ， 用 户 需要 对 图 书 资源 进行 搜索 时 ， 只 需要 单 击 相应 的 超 链 
接 ， 就 可 以 进入 该 页 面 以 实现 对 图 书 的 搜索 了 。 


21.5.5 ”查看 图 书 详情 页 面 


不 管 是 在 图 书 列表 页 、 种 类 查看 页 ， 还 是 图 书 搜索 结果 页 面 ， 当 用 户 看 到 了 中 意 的 图 书后 ， 都 可 
以 单 击 该 图 书 上 的 超 链接 ， 以 查看 该 书 的 详细 情况 。 查 看 图 书 详情 页 包含 该 书 的 所 有 详细 情况 。 用 户 
可 以 选择 购买 该 图 书 从 而 启动 购物 车 功能 。 

这 里 来 说 说 购物 车 的 实现 原理 。 购 物 车 可 以 采用 多 种 实现 机 制 , 如 Cookie, Session 或 者 隐藏 帧 等 。 
这 里 将 采用 Cookie 方式 。 当 用 户 单 击 “ 把 该 书 放 入 购物 车 ”链接 后 ， 程 序 将 在 后 台 把 该 书记 录 写 入 
Cookie。 这 里 的 Cookie 写 入 工作 采用 JavaScript 来 实现 ， 因 为 使 用 JavaScript 可 以 减少 服务 器 的 负担 。 
有 关 JavaScript 操作 Cookie 的 函数 ， 请 读者 去 自行 查找 相应 内 容 。 

下 面 先 给 出 要 调用 的 JS 文件 的 具体 代码 : 

function SetCookie (name, value) ”// 设 置 名 称 为 name, 值 为 value 的 Cookie 

{var expdate = new Date(); 

expdate.setTime(expdate.getTime() + 30 * 60 * 1000); 

document.cookie = name+"="+value+";expires="+expdate.toGMTString()+";path=/"; 

alert(" 添 加 商品 "+name+" 成 功 "); 

var 

cat=window.open("21-19.php","cat","toolbar=no,menubar=no,location=no,status=no,width=420,height=280"); // 

打开 一 个 新 窗口 来 显示 统计 的 商品 信息 ， 即 显示 “手推车 ”} 


} 
function Deletecookie (name) { // 删 除名 称 为 name 的 Cookie 
var exp = new Date(); 
exp.setTime (exp.getTime() - 1); 
var cval = GetCookie (name); 
document.cookie = name + "=" + cval + "; expires=" + exp.toGMTString(); 


function Clearcookie() // 清 除 COOKIE 
t 
var temp=document.cookie.split(";"); 
var loop3; 
var ts; 


for (loop3=0;loop3<temp.length;loop3++) 
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{ 
ts=temp[loop3].split("=")[0]; 
if (ts.indexOf('mycat')!=-1) 
DeleteCookie(ts); aR ts 含 “mycat” 则 执行 清除 
J 


function getCookieVal (offset) { // 取 得 项 名 称 为 offset 的 cookie 值 
var endstr = document.cookie.indexOf (";", offset); 
if (endstr == -1) 
endstr = document.cookie.length; 
return unescape(document.cookie.substring(offset, endstr)); 


} 


function GetCookie (name) { // 取 得 名 称 为 name 的 cookie 值 

var arg = name + "="; 

var alen = arg.length; 

var clen = document.cookie.length; 

vari = 0; 

while (i < clen) { 

var j = i + alen; 

if (document.cookie.substring(i, j) == arg) 
retum getCookieVal (j); 
i = document. cookie.indexOf(" ", i) + 1; 
if (i == 0) break; 

3 


retum null; 


先 将 以 上 代码 保存 为 mycatjs， 以 方便 程序 调用 该 JS 文件 。 
下 面 给 出 查看 图 书 详情 的 代码 : 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 查 看 图 书 详情 图 书 </title>\n"; 

echo "</head>\n"; 

echo "<body>\n"; 

require "21-3.php"; 

if(!$_GETIid]) // 如 果 没 有 用 户 请 求 ， 则 显示 信息 


echo "没有 请 求 ID! <br>"; 

echo "点 <a href=\"21-6.php\"> 这 里 </a> 返 回首 页 !"; 
} 
else // 如 果 有 用 户 请 求 ， 则 执行 操作 
{ 

echo "<script language=\"javascript\" src=\"mycat.js\">\n"; 

echo "</script>"; 

require "21-1.php"; 
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$sql="select * from $table book where id='$_GET[id]"; 


$result=mysql_query($sql,$link); 
$rows=mysql_fetch_array($result); 


echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 


echo "<tr>\n"; 


echo "<td colspan=\"2\"><center><h2> 查 看 图 书 详情 </h2></center></td>\n"; 


echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td width=\"30%\"> 图 书 名 称 : </td>\n"; 
echo "<td>".$rows[book_name]."</td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 图 书 作 者 : </td>\n"; 

echo "<td>". $rows[book_author]."</td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 出 版 社 :</td>\n"; 

echo "<td>".$rows[book_pub]."</td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> ff: </td>\n"; 

echo "<td>".$rows[book_cost]." 元 </td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 所 属 类 别 : </td>\n"; 

echo "<td>".$rows[book_type]."</td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 该 书 的 数量 : </td>\n"; 

echo "<td>".$rows[book_num]." 本 </td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 该 书 的 简介 : </td>\n"; 

echo "<td>".$rows[book_description]."</td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 该 书 的 封面 扫描 图 : </td>\n"; 
echo "<td>"; 

if(!$rows[book_photo]) 

{ 


} 

echo "<img src=\"".$rows[book_photo]."\">"; 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 


$rows[book_photo]="images/nopic.gif"; 


echo "<td colspan=\"2\" align=\"centen"><input type=\"button\" value=\" 


onclick=SetCookie(\"cat". $rows[id]."\",\"1\")></td>\n"; 


echo "</tr>\n"; 
echo "</table>\n"; 


把 该 书 加 入 购物 车 \ 
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echo "</center>\n"; 
echo "</body>"; 
echo “</html>\n"; 
} 
?> 
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将 以 上 代码 保存 为 “21-10.php”， 在 PHP 执行 环境 下 运行 该 文件 (后 面 必须 带 有 相应 图 书 的 ID 


号 ) ， 其 执行 结果 如 图 21.5 所 示 。 


BEEN TT rr 
LPO SAD HEV WAW IRAV WHU E3 


anam parie 
BBE |F 

出 版 社 ， | 中 国力 儿 出 版 社 
Eit: 2077. 

HREAN. lz 

访 书 的 数量 ， |100 本 


读书 的 简介 ， |1212 


读书 的 封面 扫 拓 
图 ， 


图 21.5 查看 图 书 详情 页 面 执行 结果 


从 图 21.5 可 以 发 现 ， 显 示 出 了 图 书 的 所 有 详细 信息 ， 并 且 用 户 还 可 以 通过 单 击 “ 把 该 书 放 入 购物 


车 ”按钮 来 启动 购物 车 。 


21.6 ”购物 车 的 实现 


在 21.5 节 的 查看 图 书 详情 页 面 中 已 经 出 现 了 
机 制 。 
这 一 节 来 详细 介绍 ， 如 何 实现 购物 车 ， 及 让 月 


2161 查看 当前 购物 车 


购物 车 。 该 程序 中 的 购物 车 采用 Cookie 这 样 的 实现 


有 户 的 提交 内 容 转化 为 实 实在 在 的 订单 。 


该 页 面 要 实现 的 功能 是 统计 系统 中 的 当前 站 点 的 Cookie 值 。 如果 是 描述 商品 的 Cookie， 则 记录 下 
该 Cookie 值 ， 并 读 取 库 表 中 相应 商品 的 信息 显示 给 用 户 。 用 户 可 以 自由 选择 是 否 购买 已 经 加 入 购物 车 


的 商品 ， 并 且 可 以 随便 输入 购买 的 数量 。 
下 面 给 出 查看 当前 购物 车 的 详细 代码 : 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 查 看 购物 车 </title>\n"; 
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echo "</head>\n"; 

echo "<body>\n"; 

echo "<center>\n"; 

echo "<LINK href=\"style.css\" rel=stylesheet>\n"; 


if(!$_ 


í 


POST[mycat]) // 如 果 没 有 用 户 提交 显示 内 容 


require "21-1.php"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacinmt 
echo "<form method=\"post\" action=\"$PATH_INFO\">\ı 
echo "<input type=\"hidden\" name=\"mycat\" value=\"post\">"; 

echo "<tr>\n"; 

echo "<td colspan=\"4\"><center><h2> 您 的 购物 车 信息 </h2></center></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 选 择 </td>\n"; 

echo "<td> 名 称 </td>\n"; 

echo "<td> 单 价 </td>\n"; 

echo "<td> 数 量 </td>\n"; 

echo "</tr>\n"; 

$temp=array_keys($_COOKIE); 

$j=0; 

for($i=0;$i<count($temp);$i++) 

{ 


"VS NT; 


if(ereg("cat", $temp[$1])) /查找 已 添加 到 购物 车 的 商品 
{ 
$j++; 
$catid=ereg_replace("cat","",$temp[$i]); 
$sql="select * from $table book where id='$catid"; 
$result=mysql_query ($sql, $link); 
$rows=mysql_fetch_array($result); 
echo "<input type=\"hidden\" name=\"id[]\" value=\"".$rowsļid]."\">\n"; 
echo "<tr>\n"; 
echo "<td><input type=\"checkbox\" name=\"c".$j."\"></td>\n"; 
echo "<td>". $rows[book_name]."</td>\n"; 
echo "<td><input type=\"text\" value=\"".$rows[book_cost]."\" name=\"m[0\" 


size=\"5\"></td>\n"; 


else 


echo "<td><input type=\"text\" name= \"t]\" value=\"1\" size=\"3\"></td>\n"; 
echo "</tr>\n"; 
} 

} 

echo "<tr>\n"; 

echo "<td colspan=\"4\"><center>"; 

echo "<input type=\"submit\" value=\" 结 帐 \*>"; 

echo "<input type=\"button\" value=\" 继 续 购物 \" onclick=window.close()>"; 

echo "</center></td>\n"; 

echo "</tr>\n"; 

echo "</form>"; 

echo "</table>"; 


readonly 
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$id=$_POST[id]; 

$m=$_POST[m]; 

$t=$_POST[t]; 

$time=date("Y 4 m A d A"); 

require "21-1.php"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 

echo "<tr><td colspan=\"4\"><center> 您 选 购 了 以 下 商品 :</center></td></tr>"; 
echo "<tr>"; 

echo "<td> 书 名 </td>"; 

echo "<td> 单 价 </td>"， 
echo "<td> 数 量 </td 
echo "<td> 小 计 </td>"; 

echo "</tr>"; 

$j=0; 

for($i=1;$i<=count($id);$i++) /循环 显示 所 有 商品 
í 


$c="c".$i; 
if($$c!="") 
{ 
$temp=$id[$i-1]; 
$temp2=$m[$i-1]; 
$temp3=$t[$i-1]; 
$sql="select * from $table book where id='$temp"; 
$result=mysql_query ($sql, $link); 
$rows=mysql_fetch_array($result); 
echo "<tr>"; 
echo "<td>". $rows[book_name]."</td>"; 
echo "<td>". $temp2."</td>"; 
echo "<td>". $temp3."</td>"; 
$z[$j]=$m[$i-1]*$t[$i-1]; 
$temp4=$z[$j]; 
echo "<td>".$z[$j]."</td>"; 
echo "</tr>"; 
$j++; 
$sql="insert into 
S$table_order(order_user_id,order_book_id,order_book_num,order_user_name,order_cost,order_date) 
values('$_COOKIE[id]','$temp','$temp3','$_COOKIE[user]','$temp4','$time')"; 
mysql_query($sql,$link); 


} 
} 
for($i=0;$i<count($z);$i++) 
{ 

$s=$s+$z[$i]; 
} 


echo "<tr><td colspan=\"4\"><center> 总 计 :".$s."</center></td></tr>"; 
echo "<tr><td colspan=\"4\"> 已 经 生成 订单 ,点 <input type=\"button\" value=\" 这 里 结束 操作 \" 
onclick=window.close></td></tr>"; 


} 


?> 
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将 以 上 代码 保存 为 “21-19.php”。 该 文件 具备 了 查 
看 购物 车 、 选 择 选 购 的 商品 、 提 交 购 物 车 信息 等 功能 。 


它 是 购物 车 功能 的 主体 文件 。 如 果 用 户 在 浏览 商品 时 ， 和 
把 某 一 商品 加 入 购物 车 ， 系 统 会 自动 以 弹出 窗口 的 形式 my 
执行 21-19.php， 以 显示 用 户 当前 选 定 的 商品 。 其 执行 结 | 
果 如 图 21.6 所 示 。 
其 中 显示 出 了 用 户 所 选择 的 商品 及 其 价格 。 用 户 可 
以 选中 需要 购买 的 商品 ， 单 击 “ 结 账 ”按钮 提交 购物 车 ， AA 
也 可 以 单 击 “ 继 续 购物 ”按钮 ， 关 闭 该 窗口 。 Mie WANAKAA 


216.2 ”查看 用 户 历 史 订 单 


用 户 在 提交 购物 车 后 ， 购 物 信息 将 生成 订单 ， 所 以 应 该 使 用 户 有 权限 能 查看 所 有 的 历史 订单 。 该 
功能 实现 也 很 简单 ， 从 订单 表 里 选 取 用 户 名 为 当前 登录 用 户 的 记录 显示 出 来 即 可 。 
下 面 给 出 具体 实现 代码 : 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 查 看 登录 用 户 历史 订单 </title>\n"; 
echo "</head>\n"; 

echo "<body>\n"; 

require "21-3.php"; 

if(I$_COOKIE[usen]) 


{ 
echo "你 没有 登录 ,没有 权限 执行 这 项 操作 ! <p>"; 
echo "点 <a href=\"21-5.php\"> 这 里 </a> 进 行 登录 "; 
exit(); 

} 

else 

{ 


require "21-1.php"; 
echo "<h2> 查 看 用 户 ".$_COOKIE[user]." 的 订单 记录 </h2>"; 


$sql="select id from $table order where order_user_id='$_COOKIE[id]"; // 从 列表 中 读 出 所 有 图 书记 录 
$result=mysql_query($sql, $link) or die(mysql_error()); // 发 送 查 找 列表 请 求 
$num=mysql_num_rows($result); /| 获取 结果 条 数 

$p_count=ceil($num/10); /总 页 数 


if ($_GET["page"]==0 && !$_GET["page"]) $page=1;// 当 前 页 
else $page=$_GET["page"]; 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 


if($num<1) // 如 果 没有 记录 
{ 

echo "<tr>\n"; 

echo "<td>"; 


echo "<center><h2> 暂 时 还 没有 该 用 户 的 订单 记录 </h2></center>"; /| 输出 相应 信息 
echo "</td>\n"; 


else 
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echo "</tr>\n"; 
exit(); 1/ 退出 所 有 PHP 代码 


// 如 果 有 记录 ， 则 执行 相应 操作 


echo "<tr>\n"; 

echo "<td> 购 书 ID</td>\n"; 

echo "<td> 购 书 数量 </td>\n"; 

echo "<td> 购 书 总 额 </td>\n"; 

echo "<td> 订 单 状态 </td>\n"; 

echo "<td> 提 交 日 期 </td>\n"; 

echo "</tr>\n"; 

$s=($page-1)*10; 

$sql="select * from $table order where order user id-'$ COOKIE[id] order by id limit $s,10"; 

$result=mysql_query($sql,$link); 

while($rows=mysql_fetch_array($result) 

{ 
echo "<tr>\n"; 
echo "<td>". $rows[order_book_id]."</td>\n"; 
echo "<td>". $rows[order_book_num]."</td>\n"; 
echo "<td>". $rows[order_cost]."</td>\n"; 
echo "<td>". $rows[order_state]."</td>\n"; 
echo "<td>". $rows[order_date]."</td>\n"; 
echo "</tr>\n"; 

} 

echo "</table>"; 

$prev page-$page-1; 

$next_page=$page+1; 


echo " <p align=\Vcenten"> "; 

if($page>1) 

t echo "<a href='$PATH_INFO?page=1'> 第 一 页 </a> |" 

H ($prev_page>=1) 

t echo "<a href='$PATH_INFO?page=$prev_page'> 上 一 页 </a> |" 
($next_page<=$p_count) 

echo "<a href='$PATH_INFO?page=$next_page'> 下 一 页 </a> |" 
} 


if ($page<$p_count) 
{ 


echo "<a href='$PATH_INFO?page=$p_count'> 最 后 一 页 </a></p>\n"; 
} 
echo "</center>"; 
echo "</body>"; 
echo "</html>"; 
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把 以 上 代码 保存 为 “21-20.php”。 这 里 可 以 方便 用 户 随时 查看 当前 用 户 的 历史 订单 记录 。 
21.7 管理 功能 的 实现 


这 里 的 管理 功能 包括 两 层 含义 : 一 是 普通 用 户 可 以 更 改 自己 的 注册 信息 、 密 码 及 查看 购物 车 等 内 
容 ， 另 一 层 含义 是 管理 员 可 以 添加 或 者 修改 图 书 类 别 、 添 加 修改 新 的 图 书 、 查 看 处 理 订单 、 查 看 销售 
记录 等 。 

可 以 看 出 ， 不 管 对 于 普通 用 户 还 是 管理 
者 ， 后 台 的 管理 功能 都 是 十 分 重要 的 。 这 
节 就 来 逐个 实现 这 些 后 台 管理 功能 。 这 里 采 


EECEETETTEECTTE 
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用 这 样 的 形式 ， 所 有 管理 操作 的 链接 都 集中 aa LIWE 
在 一 个 页 面 上 ， 即 用 户 登 录 页 ， 用 户 在 登录 Er 


前 显示 的 是 登录 界面 ， 而 在 登录 之 后 ， 则 显 
示 所 有 操作 的 链接 ， 如 图 21.7 所 示 。 

通过 这 个 界面 ， 普 通用 户 ， 或 者 管理 员 
可 以 执行 相应 的 操作 。 当 然 只 有 管理 员 才 能 
执行 的 操作 ， 普 通用 户 是 看 不 到 的 。 图 21.7 管理 员 登 录 后 的 “管理 入 口 ”执行 结果 


21.7.1 更 改 用 户 信息 


注册 用 户 的 信息 在 注册 后 并 不 是 一 成 不 变 的， 用 户 可 以 自由 更 改 自己 的 信息 ， 而 用 户 信息 的 更 改 
的 实质 就 是 改变 表 中 特定 项 的 记录 。 先 给 出 用 户 一 个 人 机 交互 界面 ， 要 求 用 户 输入 更 改 的 内 容 ， 内 容 
输入 后 ， 转 到 后 台 ， 对 相应 项 进行 更 改 操作 。 

下 面 给 出 具体 代码 : 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 修 改 注册 用 户 信息 </title>\n"; 
echo "</head>\n"; 

echo "<body>\n"; 

echo "<center>\n"; 

require "21-3.php"; 

if(!$_COOKIE[user]) 


echo "您 还 没有 登录 ! <p>"; 
echo "点 <a href=\"21-5.php\"> 这 里 </a> 进 行 登录 "; 
exit(); 


else 


{ 
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if(!$_POST[email]) 


{ 


echo "<script language=\"javascript\">\n"; 

echo "function juge(theForm)\n"; 

echo "An"; 

echo "tif (theForm.email.value == \"\")\n"; 

echo "Win"; 

echo "t\talert(\" 请 输入 邮箱 ! \");\n"; 

echo "\tittheForm.email.focus()\n"; 

echo "\t\treturn (false);\n"; 

echo "\t}\n"; 

echo "An"; 

echo "function s_photo(the)\n"; 

echo "An"; 

echo "\tdocument.img.src='images/'+the.photo.value+'.bmp';\n"; 

echo "Jn"; 

echo "</script>\n"; 

require "21-1.php"; 

$sql="select * from $table user where id='$_COOKIE[id]"; 
$result=mysql_query($sql,$link); 

$rows=mysql_fetch_array($result); 

echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"80%\">\n"; 

echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)\">\n"; 
echo "<tr>"; 

echo "<td colspan=\'2\"> 以 下 几 项 是 可 以 修改 的 : </td>\n'"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 用 户 地 址 : </td>\n"; 

echo "<td><input type=\"text\" name=\"address\" value=\"".$rows[address]."\"></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 用 户 邮箱 : </td>\n"; 

echo "<td><input type=\"text\" name=\"email\" value=\"". $rows[email].\"></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 用 户 QQ: </td>\n"; 

echo "<td><input type=\"text\" name=\"qq\" value=\"".$rows[qq]."\"></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 用 户 MSN: </td>\n"; 

echo "<td><input type=\"text\" name=\"msn\" value=\"".$rows[msn]."\"></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 用 户 图 像 : </td>\n"; 

echo "<td>"; 

echo "<select name=\"photo\" size=\"1\" onchange=\"s_photo(this.form)\">\n"; 
for($i=1;$i<21;$i++) 

£ 


echo "<option value=".$i.">".$i."</option>\n";; 


bi i 
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} 
echo "</select>\n"; 
echo "<img src=\"images/".$rows[photo]."\" name=\"img\">\n"; 
echo "</td>\n"; 
echo "</tr>\n"; 
echo "<tr>"; 


echo "<td colspan=\"2\"><center> <input type=\"submit\" value=\" 确 认 提 交 \> </center></td>vn'"; 


echo "</tr>\n"; 
echo "</form>\n"; 
echo "</table>\n"; 


else 


$email=$_POST[email]; 

$address=$_POST[address]; 

$qq=$_POST[qq]; 

$msn=$_POST[msn]; 

S$photo=$_POST[photo].".bmp"; 

require "21-1.php"; 

$sql="update Stable_user 
email='$email',address='$address',qq='$qq'",msn='$msn', photo='$photo' where id='$_COOKIE[id]"; 

if(mysql_query($sql,$link)) 


echo "修改 注册 信息 成 功 ， 现 在 返回 首页 "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=21-6.php\">"; 


} 
else 
echo "修改 注册 信息 失败 ， 现 在 返回 更 改 信息 页 "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=21-11.php\">"; 
} 
} 
} 
?> 


set 


把 以 上 代码 保存 为 “21-11.php”。 这 样 ， 当 用 户 需 要 对 注册 信息 进行 更 改 时 就 可 以 调用 该 页 面 。 


21.7.2 ”更改 用 户 密 码 


密码 始终 是 一 个 比较 敏感 的 选项 ， 因 为 它 是 用 户 进入 系统 的 一 个 钥匙 。 所 以 要 把 密码 单独 放出 来 
更 改 。 不 过 更 改 密码 的 原理 同 更 改 普通 信息 一 样 ， 对 用 户 的 输入 进行 判断 ， 如 果 符 合 条 件 ， 就 用 新 密 


人 码 蔡 换 旧 密码 。 
具体 过 程 请 参考 以 下 代码 : 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 修 改 注册 用 户 密码 </title>\n"; 
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echo "</head>\n"; 
echo "<body>\n"; 
echo "<center>\n"; 
require "21-3.php"; 
if(!$_COOKIE[user]) 


1 
echo "你 还 没有 登录 ! <p>"; 
echo "点 <a href=\"21-5.php\"> 这 里 </a> 进 行 登录 "; 
exit(); 

} 

else 

{ 


if(!$_POST[password]) 

{ 
echo "<script language=\"javascript\">\n"; 
echo "function juge(theForm)\n"; 
echo "An"; 
echo "if (theForm.password.value == \"\")\n"; 
echo "Win"; 
echo "\t\talert(\" 请 输入 旧 密 码 ! \");\n"; 
echo "\t\ttheForm.password.focus();\n"; 
echo "\t\treturn (false);\n"; 
echo "Win"; 
echo "if (theForm.newpassword.value == \"\")\n"; 
echo "Win"; 
echo "\t\talert(\" 请 输入 新 密码 !\");\n"; 
echo "\t\ttheForm.newpassword.focus();\n"; 
echo "\t\treturn (false);\n"; 
echo "Win"; 
echo "if (theForm.newpassword.value.length <8)\n"; 
echo "Win"; 
echo "ttalert(\" 密 码 要 在 8 位 以 上 ! VAN" 
echo "\t\ttheForm.newpassword.focus();\n"; 
echo "\t\treturn (false);\n"; 
echo "Min"; 


echo "if (theForm.newpassword.value != theForm.repassword.value)\n"; 


echo "Win"; 

echo ttalert( 重 复 输入 的 密码 不 一 致 ! jn 
echo "\t\ttheForm.repassword.focus();\n"; 
echo "\t\treturn (false);\n"; 

echo "\t}\n"; 

echo "An"; 

echo "</script>\n"; 


echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)\">\n"; 


echo "<tr>\n"; 

echo "<td colspan=\"2\"> 修 改 用 户 密码 </td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 输 入 旧 密 码 : </td>\n"; 


“Ss 
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echo "<td>"; 

echo "<input type=\"password\" name=\"password\">"; 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 输 入 新 密码 ;</td>\n"; 

echo "<td>"; 

echo "<input type=\"password\" name=\"newpassword\">"; 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 再 输入 一 次 : </td>\n"; 

echo "<td>"; 

echo "<input type=\"password\" name=\"repassword\">"; 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td colspan=\"2\"><center>"; 

echo "<input type=submit value=\" 提 交 \> "; 

echo "</center></td>\n"; 

echo "</tr>\n"; 

echo "</form>"; 

echo "</table>\n"; 

echo "</center>\n"; 

echo "</body>\n"; 

echo "</html>\n"; 


else 


require "21-1.php"; 
$password=md5($_POST[password]); 
$newpassword=md5($_POSTInewpassword]); 
$id=$_COOKIE[id]; 
$sql="select id from $table user where name='$_COOKIE[usen and password-'$password'"; 
$result=mysql_query($sql,$link); 
$nums=mysql_num_rows($result); 
if($nums<1) 
{ 

echo "输入 的 用 户 密码 错误 ! <p>"; 

echo "请 重新 输入 ! "; 

echo "<meta http-equiv=\"refresh\" content=\"2; url=21-12.php\">"; 
} 
else 
{ 

$sql="update $table user set password-'$newpassword' where id='$id"; 

if(mysql_query($sql,$link)) 

í 

echo "修改 用 户 密码 成 功 ， 现 在 返回 首页 "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=20-6.php\">"; 
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echo "修改 用 户 密码 失败 ， 现 在 返回 修改 密码 页 "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=21-12.php\">"; 


保存 上 面 代码 为 “21-12.php”， 以 备 后 用 。 
21.7.3 为 图 书 添 加 新 的 分 类 


图 书 类 别管 理 中 的 重要 一 项 就 是 添加 新 的 分 类 。 在 实际 生活 中 ， 图 书 的 种 类 是 多 种 多 样 的， 管理 
员 应 该 为 图 书 添加 分 类 及 二 级 分 类 ， 其 实质 是 为 分 类 表 添加 新 的 记录 。 
请 参考 以 下 代码 : 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 增 加 新 的 图 书 类 别 </title>\n"; 
echo "</head>\n"; 

echo "<body>\n"; 

echo "<center>\n"; 

require "21-3.php"; 

require "21-1.php"; 

$sql="select admin from $table user where id='$_COOKIE[id]"; 
$result=mysql_query($sql,$link); 
$rows=mysql_fetch_array($result); 
if($rows[0]!=3) 


echo "你 没有 权限 执行 这 项 操作 !"; 


exit(); 

else 
if(!$_POST[type]) 
{ 


echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 

echo "<form method=\"post\" action=\"".$_SERVER[PHP_SELF]."\">\n"; 

echo "<tr>\n"; 

echo "<td colspan=\"2\"><center><h2> 创 建 图 书 分 类 第 一 步 </h2></center></td>\n"; 
echo "</tr>"; 

echo "<tr>\n"; 

echo "<td> 选 择 创建 类 别 </td>\n"; 

echo "<td>"; 

echo "<select size=\"1\" name=\"type\">\n"; 
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echo "<option value=\"1\"> 主 类 别 </option>\n"; 
echo "<option value=\"2\"> 分 类 别 </option>\n"; 
echo "</select>\n"; 

echo "</td>\n"; 

echo "</tr>"; 

echo "<tr>\n"; 

echo "<td colspan=\"2\"><center> <input type=submit value=\" F—#\"></td>\n"; 
echo "</tr>\n"; 

echo "</form>\n"; 

echo "</table>\n"; 

echo "</center>\n"; 

echo "</body>"; 

echo "</html>\n"; 


} 
else if(!$_POST[type_name]) 
{ 
echo "<script language=\"javascript\">\n"; 
echo "function juge(theForm)\n"; 
echo "An"; 
echo "\tif (theForm.type_name.value == \"\")\n"; 
echo "Win"; 
echo "\t\talert(\" 请 输入 类 别名 称 !\");\n"; 
echo "\t\ttheForm.topic_name.focus();\n"; 
echo "\t\tretum (false);\n"; 
echo "Win"; 
echo "\tif (theForm.type_description.value == \"\")\n"; 
echo "Win"; 
echo "ttalert(\"' 请 输入 类 别 介绍 ! \");\n"; 
echo "\t\ttheForm.topic_description.focus();\n"; 
echo "Wtretum (false);\n"; 
echo "Win"; 
echo "An"; 
echo "</script>\n"; 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<form method=\"post\ action=\"".$_SERVER[PHP_SELF]."\" onsubmit=\"return 
juge(this)\\">\n"; 
echo "<tr>\n"; 
echo "<td colspan=\"2\"><center><h2> 创 建 图 书 分 类 第 二 步 </h2></center></td>\n"; 
echo "</tr>"; 
echo "<input type=\"hidden\" name=\"type\" value=\"".$_POST[type]."\">"; 
if($_POST[type]==2) 
{ 
echo "<tr>\n"; 
echo "<td> 选 择 分 类 别 所属 主 类 </td>\n"; 
echo "<td>"; 
echo "<select size=\"1\" name=\"p_id\">\n"; 
$sql="select id,type_name from $table type where p_id=0"; 
$result=mysql_query($sql,$link); 
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while($rows=mysql_fetch_array($result)) 


{ 
echo "<option value=\"". $rows[id]."\">". $rows[type_name]."</option>\n"; 
} 
echo "</select>\n"; 
echo "</td>\n"; 
echo "</tr>"; 
} 
echo "<tr>\n"; 
echo "<td> 输 入 类 别名 称 </td>\n"; 
echo "<td>"; 


echo "<input type=\"text\" name=\"type_name\">\n"; 
echo "</td>\n"; 

echo "</tr>"; 

echo "<tr>\n"; 

echo "<td> 输 入 类 别 介绍 </td>\n"; 

echo "<td>"; 

echo "<input type=\"text\" name=\"type_description\">\n"; 
echo "</td>\n"; 

echo "</tr>"; 

echo "<tr>\n"; 


echo "<td colspan=\"2\"><center><input type=button 


onclick=\"history.go(-1)\"><input type=submit value=\" F —#\"></td>\n"; 


else 


$table_type(p_id,type_name,type_description)values('$p_id','$type_name','$type_description')"; 


echo "</tr>\n"; 
echo "</form>\n"; 
echo "</table>\n"; 
echo "</center>\n"; 
echo "</body>"; 
echo "</html>\n"; 


$type=$_POST[type]; 
$type_name=$_POSTI[type_name]; 
$type_description=$_POSTI[type_description]; 
if($type==2) 

{ 


} 
else $p_id=0; 
$sql="insert 


$p_id=$_POST[p_id]; 


if(mysql_query($sql,$link)) 


echo "增加 新 类 别 操作 成 功 ， 现 在 返回 首页 !"; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=21-6\">"; 
} 


else 


{ 


value=\" 
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into 
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echo "增加 新 类 别 操作 失败 ， 现 在 返回 !"; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=21-13.php\">"; 


?> 


将 上 述 代码 保存 为 “21-13.php”。 当 管理 员 调 用 该 文件 时 ， 其 执行 结果 如 图 21.8 所 示 。 从 图 21.8 


中 选取 相应 的 创建 类 别 单 击 “ 下 一 步 ” 按 钮 ， 执 行 结 果 如 图 21.9 如 示 。 
ps a 
id Lu 
r z 
创 是 图 书 分 类 第 二 步 
直 城 首页 | HARS | 分 类 坦 看 | 图书 搜索 | 管理 入 口 
尘 择 分 类 别 所 属 主 类 [ss 
创建 图 书 分 类 第 一 步 PETETA 一 
ES 到 [EZE] Epes] | 
Elm 5 Tes i 
E COO O Z| COO Er zi 
图 21.8 ”增加 新 类 别 的 第 1 步 图 21.9 增加 新 类 别 的 第 2 步 


在 图 21.8 中 输入 类 别 的 名 称 及 类 别 介绍 ， 如 果 创 建 的 类 别 是 分 类 别 ， 还 要 对 该 分 类 别 所 属 主 类 别 
进行 选择 。 输 入 完成 后 ， 就 可 以 完成 对 相应 类 别 的 添加 。 


21.7.4 修改 已 经 存在 的 分 类 


设置 好 的 分 类 不 一 定 是 最 合适 的 ， 所 以 也 要 允许 管理 员 对 分 类 进行 修改 ， 如 修改 分 类 名 称 、 修 改 
分 类 的 说 明 、 修 改 二 级 分 类 所 属 的 主 分 类 等 。 这 些 操作 通过 互动 表单 及 强大 的 MySQL 数据 库 语 句 都 
能 够 实现 。 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 修 改 现 有 的 图 书 类 别 </title>\n"; 
echo "</head>\n"; 

echo "<body>\n"; 

echo "<center>\n"; 

require "21-3.php"; 

require "21-1.php"; 

$sql="select admin from $table user where id='$_COOKIEfid]"; 
$result=mysql_query($sql,$link); 
$rows=mysql_fetch_array($result); 
if($rows[0]!=3) 


echo "你 没有 权限 执行 这 项 操作 !"; 
exit(); 


else 
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if(!$_POSTI[id]) 

{ 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<form method=\"post\" action=\"".$_SERVER[PHP_SELF]."\">\n"; 
echo "<tr>\n"; 

echo "<td colspan=\"4\"><center><h2> 修 改 图 书 分 类 第 一 步 </h2></center></td>\n"; 
echo "</tr>"; 

echo "<tr>\n"; 

echo "<td> 选 择 图 书 分 类 </td>\n"; 

echo "<td> 分 类 类 型 </td>\n"; 

echo "<td> 图 书 分 类 名 称 </td>\n"; 

echo "<td> 该 类 别 简介 </td>\n"; 

echo "</tr>"; 

$sgl-"selectid,p id,type name,type description from $table type"; 
Sresult=mysql_query($sql,$link); 
while($rows=mysql_fetch_array($result) 


{ 


echo "<tr>\n"; 

echo "<td><input type=\"radio\" name=\"id\" value=\"". $rows[id]."\"></td>\n"; 
echo "<td>"; 

if($rows[p_id]==0) 


echo " 主 分 类 "; 
} 


else 


echo " 子 分 类 "; 
} 
echo "</td>\n"; 
echo "<td>". $rows[type_name]."</td>\n"; 
echo "<td>". $rows[type_description]."</td>\n"; 
echo "</tr>\n"; 
} 
echo "<tr>\n"; 
echo "<td colspan=\"4\"><center><input type=submit value=\" 下 一 步 \"></td>\n"; 
echo "</tr>\n"; 
echo "</form>\n"; 
echo "</table>\n"; 
echo "</center>\n"; 
echo "</body>"; 
echo "</html>\n"; 


} 

else if(!$_POST[type_name]) 

{ 
echo "<script language=\"javascript\">\n"; 
echo "function juge(theForm)\n"; 
echo "An"; 
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echo "if (theForm.type_name.value == \"\")\n"; 
echo "Win"; 
echo "\t\talert(\" 请 输入 类 别名 称 ! \");\n"; 
echo "\t\ttheForm.type_name.focus();\n"; 
echo "\t\treturn (false);\n"; 
echo "Win"; 
echo "tif (theForm.type_description.value == \"\")\n"; 
echo "Win"; 
echo "\t\talert(\" 请 输入 类 别 介绍 ! \");\n"; 
echo "\t\ttheForm.type_description.focus();\n"; 
echo "\t\treturn (false);\n"; 
echo \t}\n"; 
echo "An"; 
echo "</script>\n"; 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<form method=\"post\" action=\"".$_SERVER[PHP_SELF]."\" onsubmit=\"return 
juge(this)\">\n"; 
echo "<tr>\n"; 
echo "<td colspan=\"2\"><center><h2> 修 改 图 书 分 类 第 二 步 </h2></center></td>\n"; 
echo "</tr>"; 
echo "<input type=\"hidden\" name=\"id\" value=\"".$_POST[id]."\">"; 
$sql="select * from $table_type where id='$_POST[id]"; 
$result=mysql_query($sql,$link); 
$rows=mysql_fetch_array($result); 
if($rows[p_id]!=0) 
4 
echo "<tr>\n"; 
echo "<td> 选 择 子 类 别 所属 主 类 </td>\n"; 
echo "<td>"; 
echo "<select size=\"1\" name=\"p_id\">\n"; 
$sql2="select id,type_name from $table type where p_id=0"; 
$result2=mysql_query($sql2,$link); 
while($rows2=mysql_fetch_array($result2)) 
echo "<option value=\".$rows2[id]; 
if($rows2[id]==$rows[p_id]) echo " checked "; 
echo ">".$rows2[type_name]."</option>\n"; 
} 
echo "</select>\n"; 
echo "</td>\n"; 
echo "</tr>"; 
} 
echo "<tr>\n"; 
echo "<td> 输 入 类 别名 称 </td>\n"; 
echo "<td>"; 
echo "<input type=\"text\" name=\"type_name\" value=\"".$rows[type_name]."\">\n"; 
echo "</td>\n"; 
echo "</tr>"; 
echo "<tr>\n"; 
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echo "<td> 输 入 类 别 介绍 </td>\n"; 
echo "<td>"; 
echo "<input type=\"text\" name=\"type_description\" value=\"". $rows[type_description]."\">\n"; 
echo "</td>\n"; 
echo "</tr>"; 
echo "<tr>\n"; 
echo "<td colspan=\"2\"><center><input type=button value=" 上 一 # V 
onclick=\"history.go(-1)\"><input type=submit value=\" 下 一 步 *></td>\n"; 
echo "</tr>\n"; 
echo "</form>\n"; 
echo "</table>\n"; 
echo "</center>\n"; 
echo "</body>"; 
echo "</html>\n"; 
} 
else 
{ 
$id=$_POSTIid]; 
$type=$_POST[type]; 
$type_name=$_POST[type_name]; 
$type_description=$_POST[type_description]; 
if($_POST[p_id]) 
{ 


} 


else 


$p id-$ POSTIp id); 


$p_id=0; 


$sql="update Stable type set 
pid-'$p id',type name-'$type name',type description-'$type description' where id=$id"; 
if(mysql_query($sql,$link)) 


echo "修改 图 书 分 类 操作 成 功 ， 现 在 返回 图 书 分 类 列表 !"; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=21-8\">"; 


} 
else 
echo "修改 图 书 分 类 操作 失败 ， 现 在 返回 !"; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=21-14.php\">"; 
} 
$ 
} 
?> 


将 上 面 的 代码 保存 为 “21-14.php”， 以 备 后 用 。 管 理 员 调用 该 页 面 时 其 执行 结果 如 图 21.10 所 示 。 
该 页 面 显示 出 了 所 有 的 图 书 类 别 。 从 中 选取 相应 类 别 ， 单 击 前 面 的 单 选 按钮 ， 然 后 单 击 “下 一 步 ” 按 
钮 ， 执 行 结果 如 图 21.11 所 示 。 
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21.10 ”修改 已 有 类 别 第 1 步 执 行 结果 图 21.11 修改 已 有 类 别 第 2 步 执行 结果 
从 图 21.11 可 以 看 出 , 可 以 修改 类 别名 称 及 类 别 介绍 , 如 果 选 择 修改 的 类 别 是 子 类 别 还 可 以 重新 选 


择 该 子 类 别 所 属 的 分 类 别 。 按 需求 对 各 项 内 容 进行 填写 ， 单 击 “ 下 一 步 ” 按 钮 ， 即 可 完成 对 本 类 别 的 
修改 。 


217.5 增加 新 的 图 书 


图 书 的 库存 量 总 是 在 不 断 地 增加 ， 所 以 增加 新 图 书 的 功能 是 必 不 可 少 的 。 特 别 是 在 使 用 初期 ， 必 
须 把 库存 图 书 “ 入 库 ”。 这 里 说 的 入 库 并 不 是 通常 意义 上 的 放 入 仓库 ， 而 是 把 所 有 图 书 的 相关 信息 存 
入 数据 库 的 表 中 。 使 用 下 面 代码 即 可 实现 这 样 的 功能 。 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 增 加 新 的 图 书 </title>\n"; 
echo "</head>\n"; 

echo "<body>\n"; 

echo "<center>\n"; 

require "21-3.php"; 

require "21-1.php"; 

$sql="select admin from $table user where id='$_COOKIEfid]"; 
$result=mysql_query($sql,$link); 
$rows=mysql_fetch_array($result); 
if($rows[0]!=3) 


echo "你 没有 权限 执行 这 项 操作 !"; 
exit(); 


} 


else 


if(!$_POST[book_name]) 
{ 
$sql="select id,type_name from $table type where p_id=0"; 
Sresult=mysql_query($sql,$link); 
$i=0; 
while($rows=mysql_fetch_array($result)) 
$ 
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$j=0; 

$temp[$il[0]=$rows[type_name]; 

$flag[$il[0]=$rows[id]; 

$sql2="select id,type_name from $table type where p id-'$rowslid)'"; 
$result2=mysql_query($sql2,$link); 
while($rows2=mysql_fetch_array($result2)) 


$j++; 
$temp[$i][$j]=$rows2[type_name]; 
S$flag[$i][$j]=$rows2[id]; 

} 

$i++; 


} 
echo "<script language=javascript> 
function Juge(theForm) 
1 
if (theForm.book_name.value == \'\") 
{ 
alert(\" 请 输入 书 名 \"); 
theForm.book name.focus(); 
retum (false); 


if (theForm.book_author.value == \"\") 


alert(\" 请 输入 作者 人 ); 
theForm.book_authorfocus(); 
retum (false); 


} 


if (theForm.cost.value == \"\") 


{ 
alet" iHi A BARN"); 
theForm.cost.focus(); 
retur (false); 


} 


if (theForm.book_num.value == \"\") 


í 
alert(\" 请 输入 数量 \"); 
theForm.book_num.focus(); 
retum (false); 


} 
if (theForm.book_description.value == \"\") 


d 
alert(\" 请 输入 内 容 简 介 I"); 
theForm.book_description.focus(); 
retum (false); 

} 


} 
function change(){ 


for(var i=document.f.s_type.length;i>=0;i--) document.f.s type.optionsfij-null; 
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switch(document.fm_type.options[documentf.m_type.selectedlndex].text)fn"; 
for($i=0;$i<count($temp); $i++) 


{ 
echo 


"case "."\"". $temp[$i[0]."\":\n"; 


for($j=1;$j<count($temp[$i]);$j++) 


echo 


"document.f.s_type.options[".($j-1)."]=new 


Option(\"".$temp[$i][$j]."\".\"".$flag[$i][$j]."\".false,false);\n"; 


echo 


} 


"break;\n"; 


echo "MN\n}\n</script>\n"; 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 


echo "<form method=\"post\" action=\"".$_SERVER[PHP_SELF]."\" 


ENCTYPE=\"multipart/form-data\">\n"; 


echo "<tr>\n"; 

echo "<td colspan=\"2\"><center><h2> 增 加 新 的 图 书 第 一 步 </h2></center></td>\n"; 
echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 输 入 图 书 名 称 : </td>\n"; 

echo "<td>"; 

echo "<input type=\"text\" name=\"book_name\">"; 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 输 入 图 书 作 者 : </td>\n"; 

echo "<td>"; 

echo "<input type=\"text\" name=\"book_authon\">"; 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 输 入 出 版 社 : </td>\n"; 

echo "<td>"; 

echo "<input type=\"text\" name=\"book_pub\">"; 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 输 入 售 价 : </td>\n"; 

echo "<td>"; 

echo "<input type=\"text\" name=\"book_cost\">"; 
echo "</td>\n"; 

echo "</tr>\n"; 

echo "<tr>\n"; 

echo "<td> 选 择 所属 类 别 : </td>\n"; 

echo "<td>"; 

echo "ERA: "; 

echo "<select size=\"1\" name=\"m_type\" onchange=\"change()\">\n"; 
for($i=0;$i<count($temp);$i++) 

{ 


} 


echo "<option value=".$flag[S$i][0].">".$temp[$i[O]; 


namez\"f\" 


else 
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echo "</select>\n<br>"; 
echo "分 类 别 :"; 
echo "<select size=\"1\" name=\"s_type\">\n"; 
for($i=1;$i<count($temp[0]);$i++) 
{ 
echo "<option value=".$flag[0][$i].">".$temp[0][$i]; 
} 
echo "</select>\n"; 
echo "</td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 输 入 该 书 的 数量 : </td>\n"; 
echo "<td>"; 
echo "<input type=\"text\" name=\"book_num\">"; 
echo "</td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 输 入 该 书 的 简介 : </tdə\n"; 
echo "<td>"; 
echo "<textarea name=\"book_description\" cols=\"30\" rows=\"5\"></textarea>"; 
echo "</td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 上 传 该 书 的 封面 扫描 图 : </td>\n"; 
echo "<td>"; 
echo "<input type=\"file\" name=\"photo\">"; 
echo "</td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td colspan=\"2\"><center><input type=submit value=\" 下 一 步 \"></td>\n"; 
echo "</tr>\n"; 
echo "</form>\n"; 
echo "</table>\n"; 
echo "</center>\n"; 
echo "</body>"; 
echo "</html>\n"; 


$book_name=$_POST[book_name]; 
$book_author=$_POST[book_author]; 
$book_pub=$_POST[book_pub]; 
$book_cost=$_POST[book_cost]; 
$m_type=$_POST[m_type]; 
$s_type=$_POST[s_type]; 
$book_num=$_POST[book_num]; 
$book_description=$_POST[book_description]; 
if($photo) 
{ 

S$filepath="uploads/"; 
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$file temp-erplode(".",$photo name); 
S$filename=$filepath.date(YmdHis).".".$file_temp[{1]; 
copy($ photo, $filename); 

unlink($photo); 


} 
$sql="insert into $table_book 


(book_name,book_author,book_pub,book_cost,book_type,book_num,book_description,book_photo) 
values('$book name','$book author','$book pub',$book cost','$s type',"$book num',/'$book description','$filen 
ame')"; 
if(mysql_query($sql,$link)) 
{ 
$sql="update $table_type set type_num=type_num+1 where id='§$m_type"; 


mysql_query($sql,$link); 
$sql="update $table type set type_num=type_num+1 where id-'$s type"; 


mysql_query($sql,$link); 
echo "添加 新 的 图 书 操作 成 功 ， 现 在 返回 查看 全 部 图 书页 ! "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=21-7\">"; 


} 


else 


echo "添加 新 的 图 书 操作 失败 ， 现 在 返回 重新 输入 !"; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=21-15.php\">"; 


} 


?> 
把 上 述 代码 保存 为 “21-15.php”。 这 样 在 新 书 “ 入 库 ” 时 就 可 以 通过 该 文件 来 实现 了 。 其 执行 结 
果 如 图 21.12 所 示 。 


lel 
D Aa IAD AHU ML] 
增加 新 的 图 书 第 一 步 H 
Aa Eee 
祝 入 回忆 作者 I 
RAHE L | 
RAS mm 
ELEUN +a. pesa 
eA] 
UA i 
BABAN, Z 
B 
aa [me] 
下 - 步 1 到 
a CE me 到 
图 21.12 增加 新 的 图 书 执行 结果 
在 这 里 ， 可 以 输入 图 书 的 所 有 相关 信息 。 包 括 图 书 的 名 称 、 作 者 、 出 版 社 、 售 价 、 所 属 主 类 别 与 


分 类 别 、 存 货 数量 、 书 的 内 容 简 介 以 及 封面 扫描 图 等 。 其 中 封面 扫描 图 一 项 需要 上 传 。 全 部 填写 完毕 
单 击 “ 下 一 步 ”按钮 ， 即 可 生成 记录 。 
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21.7.6 ”修改 已 有 图 书 


图 书 在 入 库 以 后 ， 由 于 种 种 原因 ， 需 要 对 图 书 的 信息 进行 更 改 ， 这 也 是 可 以 实现 的 。 同 更 改 用 户 
注册 信息 一 样 ， 先 给 出 一 个 人 机 交互 界面 ， 由 管理 员 输 入 更 改 的 内 容 ， 内 容 输 入 后 ， 在 后 台 对 相应 的 
内 容 进 行 更 改 。 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 修 改 已 有 的 图 书 </title>\n"; 
echo "</head>\n"; 

echo "<body>\n"; 

echo "<center>\n"; 

require "21-3.php"; 

require "21-1.php"; 

$sql="select admin from $table user where id='$_COOKIE[id]"; 
$result=mysql_query($sql,$link); 
$rows=mysql_fetch_array($result); 
if($rows[0]!=3) 


echo "你 没有 权限 执行 这 项 操作 !"; 
exit(); 
} 
else 
{ 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
if(!$_POST[id]) 


$ 
$sql="select id from $table book"; /从 列表 中 读 出 所 有 图 书记 录 
$result=mysql_query($sql,$link) or die(mysql_error()); /发 送 查找 列表 请 求 
$num=mysql_num_rows($result); /获取 结果 条 数 
$p_count=ceil($num/10); /总 页 数 


if ($_GET["page"]==0 && !$_GET["page"]) $page=1;// 当 前 页 
else $page=$_GETI["page"]; 


if($num<1) // 如 果 没 有 记录 
{ 
echo "<tr>\n"; 
echo "<td>"; 
echo "<center><h2> 暂 时 还 没有 图 书 的 记录 </h2></center>"; /| 输出 相应 信息 
echo "</td>\n"; 
echo "</tr>\n"; 
exit(); // 退 出 所 有 PHP 代码 
} 
else /| 如果 有 记录 ， 则 执行 相应 操作 


$s=($page-1)*10; 
$sql="select * from $table book order by id limit $s,10"; 
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$result=mysql_query($sql,$link); 
echo "<form method=\"post\" action=\"".$_SERVER[PHP_SELF]."\">"; 
echo "<tr>\n"; 
echo "<td colspan=\"5\"><center><h2> 已 有 图 书 第 一 步 : 选择 记录 </h2></center></td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 选 择 </td>\n"; 
echo "<td> 书 名 </td>\n"; 
echo "<td> 作 者 </td>\n"; 
echo "<td> 价 格 </td>\n"; 
echo "<td> 类 别 </td>\n"; 
while($rows=mysql_fetch_array($result)) /循环 显示 记录 内 容 
echo "<tr>\n"; 
echo "<td><input type=\"radio\" name=\"id\" value=\"". $rows[id]."\"></td>\n"; 
echo "<td><a href=\"21-10.php?id=". $rows[id]."\">".$rows[book_name]."</a></td>\n"; 
/显示 书 名 
echo "<td>".$rows[book_author]."</td>\n";// 显 示 作者 
echo "<td>".$rows[book_cost]."</td>\n"; /显示 价格 
$sql2="select type name from $table type where id='$rows[book_type]"; 
$result2=mysql_query($sql2); 
$rows2=mysql_fetch_array($result2); 


echo "<td>".$rows2[0]."</td>"; /显示 类 别 
echo "</tr>\n"; 
} 
echo "<tr>\n"; 
echo "<td colspan=\"5\"><center><input type=\"submit\" value=\" 修 改选 择 项 \"*></center></td>\n"; 
echo "</tr>\n"; 
echo "</form>\n"; 


} 


echo "</table>"; 
$prev_page=$page-1; 
$next_page=$page+1; 


echo " <p align=\Vcenten"> "; 

if($page>1) 

! echo "<a href='$PATH_INFO?page=1'> 第 一 页 </a> | "; 

r ($prev_page>=1) 

' echo "<a href='$PATH_INFO?page=$prev_page'> 上 一 页 </a> |" 
` ($next_page<=$p_count) 

i echo "<a href='$PATH_INFO?page=$next_page'> 下 一 页 </a> |" 
A ($page<$p_count) 

£ 


echo "<a href='$PATH_INFO?page=$p_count'> 最 后 一 页 </a></p>\n"; 
} 
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echo "</center>"; 
echo "</body>"; 


echo "</html>"; 
} 
else if(!$_POST[book_name]) 
í 
$sql="select id,type_name from $table_type where p_id=0"; 
Sresult=mysql_query($sql,$link); 
$i=0; 
while($rows=mysql_fetch_array($result) 
$j=0; 
$temp[$i][0]=$rows[type_name]; 
$flag[$i[0]=$rows[id]; 
$sql2="select id,type_name from $table type where p_id='$rows[id]"; 
Sresult2=mysql_query($sql2,$link); 
while($rows2=mysql_fetch_array($result2)) 
{ 
$j++; 
$temp[$i][$j]=$rows2[type_name]; 
Şflag[$i][$j]=$rows2[id]; 
} 
$i++; 
} 
echo "<script language-javascript> 
function Juge(theForm) 


{ 


if (theForm.book_name.value == \'\") 


{ 
alert(\" 请 输入 书 名 MN"); 
theForm.book name.focus(); 
retum (false); 


} 
if (theForm.book_author.value == \"\") 


{ 
alertQ" 请 输入 作者 N"); 
theForm.book author.focus(); 
retum (false); 


} 


if (theForm.cost.value == \"\") 


{ 
alert(\" 请 输入 书 的 价格 \"); 
theForm.cost.focus(); 
retum (false); 


} 


if (theForm.book_num.value == \"\") 


{ 
alert(\" 请 输入 数量 \"); 
theForm.book_num.focus(); 
retum (false); 
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} 
if (theForm.book_description.value == \"\") 


{ 
alert(\" 请 输入 内 容 简介 IN ); 
theForm.book_description.focus(); 
retur (false); 
} 
} 
function change(){ 
for(var i=document.f.s_type.length;i>=0;i—) document.f.s_type.options[i]=null; 
switch(document.f.m_type.options[document.f.m_type.selectedIndex].text){\n"; 
for($i=0;$i<count($temp);$i++) 
{ 
echo "case "."\"".$temp[$i][0]."\":\n"; 
for($j=1;$j<count($temp[$i]);$j++) 
echo "document.f.s_type.options[".($j-1)."]=new 
Option(\"".$temp[$i][$j]."\".\"".$flag[$i][$j]."\".false,false);\n"; 
echo "break;\n"; 
} 
echo "M\n}\n</script>\n"; 
$sql="select * from $table book where id='$_POST[id]"; 
$result=mysql_query($sql,$link); 
$rows=mysql_fetch_array($result); 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<form method=\"post\" action=\"".$_SERVER[PHP_SELF]."\" name=\"f\" 
ENCTYPE=\"multipart/form-data\">\n"; 
echo "<input type=\"hidden\" name=\"id\" value=\"".$_POST[id]."\">"; 
echo "<tr>\n"; 
echo "<td colspan=\"2\"><center><h2> 修 改 已 有 图 书 第 二 步 : 修改 相关 信息 </h2></center></td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 输 入 图 书 名 称 : </td>\n"; 
echo "<td>"; 
echo "<input type=\"text\" name=\"book_name\" value=\"". $rows[book_name]."\">"; 
echo "</td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 输 入 图 书 作 者 : </td>\n"; 
echo "<td>"; 
echo "<input type=\"text\" name=\"book_authon\" value=\"".$rows[book_author]."\">"; 
echo "</td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 输 入 出 版 社 : </td>\n"; 
echo "<td>"; 
echo "<input type=\"text\" name=\"book_pub\" value=\"".$rows[book_pub]."\">"; 
echo "</td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 输 入 售 价 : </td>\n"; 
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echo "<td>"; 
echo "<input type=\"text\" name=\"book_cost\" value=\"". $rows[book_cost]."\">"; 
echo "</td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 选 择 所 属 类 别 : </td>\n"; 
echo "<td>"; 
echo " 主 类 别 : "; 
echo "<select size=\"1\" name=\"m_type\" onchange=\"change()\">\n"; 
for($i=0;$i<count($temp);$i++) 
{ 
echo "<option value=".$flag[$il[0].">".$temp[$il[0]; 
} 
echo "</select>\n<br>"; 
echo "分 类 别 : "; 
echo "<select size=\"1\" name=\"s_type\">\n"; 
for($i=1;$i<count($temp[0]);$i++) 
i 
echo "<option value=".$flag[0][$i].">".$temp[0][$i]; 
} 
echo "</select>\n"; 
echo "</td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 输 入 该 书 的 数量 : </td>\n"; 
echo "<td>"; 
echo "<input type=\"text\" name=\"book_num\" value=\"". $rows[book_num]."\">"; 
echo "</td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 输 入 该 书 的 内 容 简介 : </td>\n"; 
echo "<td>"; 
echo "<textarea name=\"book_description\" cols=\"30\" rows=\"5\">". $rows[book_description]."</textarea>"; 
echo "</td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td> 上 传 该 书 的 封面 扫描 图 : <br> (如 果 无 改变 请 留 空 ) </td>\n"; 
echo "<td>"; 
echo "<input type=\"file\" name=\"photo\">"; 
echo "</td>\n"; 
echo "</tr>\n"; 
echo "<tr>\n"; 
echo "<td colspan=\"2\"><center><input type=submit value=\" 下 一 步 \"></td>\n"; 
echo "</tr>\n"; 
echo "</form>\n"; 
echo "</table>\n"; 
echo "</center>\n"; 
echo "</body>"; 
echo "</html>\n"; 
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$id=$_POSTTid]; 
$book_name=$_POST[book_name]; 
$book_author=$_POST[book_author]; 
$book_pub=$_POST[book_pub]; 
$book_cost=$_POST[book_cost]; 
$m_type=$_POST[m_type]; 
$s_type=$_POST[s_type]; 
$book_num=$_POST[book_num]; 
S$book_description=$_POST[book_description]; 
if($photo) 
{ 
$filepath-"uploads/"; 
$file temp-erplode(".",$photo name); 
$filename=$filepath.date(YmdHis).".". $file_temp[{1]; 
copy($photo, $filename); 
unlink($photo); 
$sql="update Stable_book set 
book_name='$book_name',book_author='$book_author,book_pub='$book_pub',book_cost='$book_cost',book 
_type='$s_type',book_num='$book_num',book_description='$book_description',book_photo='$filename'"'; 
} 


else 


{ 
$sql="update Stable_book set 
book_name='$book_name',book_author='$book_author,book_pub='$book_pub',book_cost='$book_cost',book 
_type='$s_type',book_num='$book_num',book_description='$book_description "; 
} 


if(mysql_query($sql,$link)) 


echo "修改 已 经 有 的 图 书 操作 成 功 ， 现 在 返回 查看 全 部 图 书页 ! " 
echo "<meta http-equiv=\"refresh\" content=\"2; url=21-7\">"; 


} 
else 
echo "修改 已 经 有 的 图 书 失败 ， 现 在 返回 重新 输入 !"; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=21-16\">"; 
} 
} 
} 
?> 


把 以 上 代码 保存 为 “21-16.php”。 从 以 上 代码 可 见 ， 要 对 已 有 图 书 进行 修改 共 分 3 步 。 第 1 步 ， 
选择 想 要 修改 的 图 书 。 第 2 步 ， 填 写 修改 内 容 。 这 两 步 都 需要 人 工 干预 。 第 3 步 为 后 台 操作 ， 用 输入 
的 内 容 来 蔡 换 已 经 存在 的 内 容 ， 从 而 完成 修改 操作 。 其 执行 结果 如 图 21.13 所 示 。 

图 21.13 执行 结果 为 修改 已 有 图 书 的 第 1 步 , 先 选择 想 要 更 改 的 图 书 。 通 过 选中 相应 图 书 前 的 单 选 
按钮 来 选择 相应 图 书 ， 然 后 单 击 最 下 方 的 “修改 选择 项 ”按钮 ， 开 始 对 具体 内容 进行 修改 。 执 行 结果 
如 图 21.14 所 示 。 
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pi [Ed Tt 
图 21.13 修改 图 书页 面 执行 结果 第 1 步 图 21.14 ”修改 图 书页 面 执行 结果 第 2 步 

从 图 21.14 可 以 看 出 ， 这 里 可 以 对 图 书 的 所 有 信息 进行 全 方位 的 更 改 ， 具 体 过 程 与 添加 图 书 类 似 。 
输入 完成 后 ， 单 击 最 下 方 的 “下 一 步 ” 按 钮 ， 即 可 提交 修改 内 容 。 


21.7.7 查看、 处理 所 有 未 处 理 订单 


用 户 的 购买 请 求 在 提交 后 生成 的 订单 ， 并 不 马上 生效 ， 需 要 管理 员 对 其 进行 审核 。 只 有 在 管理 员 
对 其 进行 处 理 后 ， 才 可 能 变 为 销售 记录 。 所 以 ， 管 理 员 可 以 查看 并 处 理 所 有 的 用 户 订单 。 
下 面 给 出 管理 员 查 看 并 处 理 所 有 用 户 订单 的 代码 : 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 查 看 所 有 未 处 理 订单 </title>\n"; 
echo "</head>\n"; 

echo "<body>\n"; 

require "21-3.php"; 

require "21-1.php"; 

$sql="select admin from $table user where id='$_COOKIEfid]"; 
Sresult=mysql_query($sql,$link); 
$rows=mysql_fetch_array($result); 
if($rows[0]!=3) 


echo "你 没有 权限 执行 这 项 操作 !"; 
exit(); 


else 


if(!$_POST[c]) 

{ 
echo "<script language=javascript> 
function checkall(form) 
£ 
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for (var i=0;i<form.elements.length;i++) 
{ 
var e = form.elements[i]; 
if (e.name != 'chkall') e.checked = form.chkall.checked; 


$ 
</script>"; 
echo "<h2> 查 看 用 户 所 有 未 处 理 的 订单 </h2>"; 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
echo "<form method=\"post\" action=\"".$§_SERVER[PHP_SELF]."\">\n"; 
echo "<tr>\n"; 
echo "<td> 处 理 </td>\n"; 
echo "<td> 提 交 人 </td>\n"; 
echo "<td> 书 号 </td>\n"; 
echo "<td> 书 数量 </td>\n"; 
echo "<td> 订 单 总 额 </td>\n"; 
echo "</tr>\n"; 
$sql="select * from $table order where order state-'false""; 
$result=mysql_query($sql,$link); 
while($rows=mysql_fetch_array($result) 
{ 


echo "<tr>\n"; 
echo "<td><input type=checkbox name=c[] value=". $rows[id]."></td>\n"; 
echo "<td>". $rows[order_user_name]."</td>\n"; 
echo "<td><a href=21-10.php?id=".$rows[order_book_id]." 
target=\"_blank\">". $rows[order_book_id]."</a></td>\n"; 
echo "<td>". $rows[order_book_num]."</td>\n"; 
echo "<td>". $rows[order_cost]."</td>\n"; 
echo "</tr>\n"; 
} 
echo "<tr>\n"; 
echo "<td colspan=\"5\" align=\"centen\">\n"; 
echo "<input type=\"checkbox\" name=\"chkall\" value=\"on\" onclick=\"checkall(this.form)\"> 选 择 所 有 


记录 "; 

echo "<input type=\"submit\" value=\" 提 交 所 选 记录 \">"; 
echo "</td>\n"; 
echo "</tr>"; 
echo "</form>"; 
echo "</table>\n"; 

} 

else 

{ 


$c=$_POSTIc]; 
$time=date("Y 4 m F d A"); 
for($i=0;$i<count($c);$i++) 

{ 


$temp=$c[$i]; 

$sql="update $table order set order state-'true' where id='$temp"; 
mysql_query($sql,$link); 

$sql2="insert into $table sale (sale order id,sale date)values('$temp','$time')"; 
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mysql_query($sql2, $link); 

$sql3="select order book id ,order_book_num from $table order where id-'$temp'"; 

Sresult=mysql_query($sql3,$link); 

$rows=mysql_fetch_array( $result); 

$sql4="update Stable book set book sale num=book sale num+'$rows[1] , where 
id='$rows[0]"; 

mysql_query($sql4, $link); 


} 
echo "处 理 订单 成 功 ,正在 转 到 销售 查看 页 "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=21-18.php\">"; 


} 


?> 


把 以 上 代码 保存 为 “21-17.php”， 便 于 管理 员 处 理 未 处 理 的 订单 。 
21.7.8 ”销售 记录 的 查看 


管理 员 也 可 以 查看 所 有 的 历史 销售 记录 ， 从 而 了 解 所 有 商品 的 销售 情况 。 


<?php 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 查 看 所 有 销售 记录 </title>\n"; 
echo "</head>\n"; 

echo "<body>\n"; 

require "21-3.php"; 

require "21-1.php"; 

$sql="select admin from $table user where id='$_COOKIEfid]"; 
$result=mysql_query($sql,$link); 
$rows=mysql_fetch_array($result); 
if($rows[0]!=3) 


echo "你 没有 权限 执行 这 项 操作 !"; 
exit(); 


else 


echo "<h2> 查 看 所 有 的 销售 记录 </h2>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">\n"; 
$sql="select id from $table_sale"; 

$result=mysql_query($sql,Slink); 

$num=mysql_num_rows($result); 

$p_count=ceil($num/10); 

if ($_GET["page"]==0 && !$_GET["page"]) $page=1; // 当 前 页 

else $page=$_GET["page"]; 

if($num<1) // 如 果 没 有 记录 
{ 
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echo "<tr>\n"; 

echo "<td>"; 

echo "<center><h2> 暂 时 还 没有 图 书 的 记录 </h2></center>"; // 输 出 相应 信息 

echo "</td>\n"; 

echo "</tr>\n"; 

exit(); // 退 出 所 有 PHP 代码 
} 
else // 如 果 有 记录 则 执行 相应 操作 
{ 


$s=($page-1)*10; 
$sql="select * from $table sale order by id limit $s,10"; 
Sresult=mysql_query($sql,$link); 
echo "<tr>\n"; 
echo "<td> 销 售 ID</td>\n"; 
echo "<td> 提 交 人 </td>\n"; 
echo "<td> 购 书 ID</td>\n"; 
echo "<td> 购 书 价格 </td>\n"; 
echo "<td> 处 理 日 期 </td>\n"; 
echo "</tr>\n"; 
while($rows=mysql_fetch_array($result) 
echo "<tr>\n"; 
echo "<td>". $rows[id]."</td>\n"; 
$sql2="select * from $table order where id='$rows[id]"; 
$result2-mysg! guery($sgl2,$link); 
$rows2=mysql_fetch_array($result2); 
echo "<td>". $rows2[order_user_name]."</td>\n"; 
echo "<td>". $rows2[order_book_id]."</td>\n"; 
echo "<td>". $rows2[order_cost]."</td>\n"; 
echo "<td>". $rows[sale_date]."</td>\n"; 
echo "</tr>\n"; 
} 
echo "</table>"; 
$prev_page=$page-1; 
$next_page=$page+1; 


echo " <p align=\"centeñ"> "; 

if ($page>1) 

; echo "<a href='$PATH_INFO?page=1'> 第 一 页 </a> | "; 

. ($prev_page>=1) 

i echo "<a href='$PATH_INFO?page=$prev_page'> 上 一 页 </a> |" 
i ($next_page<=$p_count) 

í echo "<a href='$PATH_INFO?page=$next_page'> 下 一 页 </a> |" 
} 


if ($page<$p_count) 
{ 
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echo "<a href='$PATH_INFO?page=$p_count'> 最 后 一 页 </a></p>\n"; 


$ 
echo "</center>"; 
echo "</body>"; 
echo "</html>"; 
3 
?> 


保存 以 上 代码 为 “21-18.php”， 可 以 便于 管理 员 查 看 所 有 销售 记录 。 
21.7.9 当前 登录 用 户 退 出 页 面 


登录 用 户 要 求 可 以 退出 系统 。 实 现 方式 很 简单 ， 就 是 清空 当前 用 户 注册 的 Cookie 值 ， 并 清空 所 有 
的 购买 商品 记录 。 

下 面 给 出 具体 实现 代码 : 

<?php 


$temp=array_keys($_COOKIE); 
for($i=0;$i<count($temp);$i++) // 人 遍历 COOKIE 数组 


setcookie("$temp[$i]",""); // 清 空 所 有 COOKIE 记录 


} 

echo "<html>\n"; 

echo "<head>\n"; 

echo "<title> 退 出 登录 成 功 </title>\n"; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=21-6.php\">"; 
echo "</head>\n"; 

echo "<body>\n"; 

require "21-3.php"; 

echo "退出 登录 成 功 ， 现 在 转 到 首页 "; 
echo "</body>"; 

echo "</html>"; 


把 以 上 代码 保存 为 “21-19.php”。 当 用 户 需要 退出 系统 时 ， 调 用 该 页 面 ， 即 可 清空 所 有 通过 该 系 
统 注 册 的 Cookie 值 ， 从 而 完成 退出 动作 。 
以 上 全 部 页 面 创建 完成 。 该 系统 的 创建 过 程 告 一 段落 。 


21.8 本 章 小 结 


这 一 章 介 绍 了 如 何 使 用 PHP 和 MySQL 来 构建 一 个 简单 的 网 上 商城 全 站 系统 。 详 细 地 介绍 了 一 个 
网 上 商城 所 应 具备 的 基本 功能 ， 及 如 何 用 PHP 来 实现 这 些 功能 。 通 过 本 章 的 学 习 ， 读 者 对 如 何 用 PHP 
构建 网 上 商城 会 有 一 个 深刻 的 认识 。 本 章 所 创建 的 网 上 商城 功能 有 限 ， 学 完 本 书 的 读者 完全 有 能 力 来 
进一步 丰富 它 的 功能 ， 使 它 更 加 完善 。 


